1、找出数字数组中最大的元素(使用Math.max函数)
| 1 2 3 | var a = [1, 2, 3, 6, 5, 4];var ans = Math.max.apply(null, a);console.log(ans); // 6 |
这题很巧妙地用了apply,如果不是数组,是很多数字求最大值,我们知道可以这样:
| 1 2 | var ans = Math.max(1, 2, 3, 4, 5, 6);console.log(ans); // 6 |
而apply的第二个参数正是一个数组,都不用进行转换了。
还有一种用eval+toString的实现:
| 1 2 3 | var a = [1, 2, 3, 6, 5, 4];var ans = eval( 'Math.max(' + a.toString() + ')');console.log(ans); // 6 |
2、转化一个数字数组为function数组(每个function都弹出相应的数字)
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | var a = [1, 2, 3, 4, 5, 6];var len = a.length;for(var i = 0; i < len; i++) { var num = a[i]; (function(num) { var f = function() { console.log(num); }; a[i] = f; })(num);}for(var i = 0; i < len; i++) a[i]();// 1// 2// 3// 4// 5// 6 |
我觉得这跟给n个a标签,弹出相应标签对应的编号是一个类型的题,用闭包保存变量到内存即可。
3、给object数组进行排序(排序条件是每个元素对象的属性个数)
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | var a = { name: 'hanzichi', age: 10, location: 'china'};var b = { name: 'curry'};var c = { name: 'kobe', sex: 'male'};Object.prototype.getLength = function() { var num = 0; for(var key in this) { if(this.hasOwnProperty(key)) num++; } return num;};var arr = [a, b, c];arr.sort(function(a, b) { return a.getLength() > b.getLength();});console.log(arr); |
这题不难,数组排序,当然是sort,排序条件是对象的属性个数,可以写个函数计算,注意可能要用hasOwnProperty判断下。
4、利用JavaScript打印出Fibonacci数(不使用全局变量)
| 1 2 3 4 5 6 | (function(a, b) { var c = a + b; console.log(c); if(c > 100) return; arguments.callee(b, c);})(-1, 1); |
这题没看明白,是打出斐波那契数列的前n项么?还是第n项...
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | function fn(n) { var a = []; a[0] = 0, a[1] = 1; for(var i = 2; i < n; i++) a[i] = a[i - 1] + a[i - 2]; for(var i = 0; i < n; i++) console.log(a[i]);}fn(5); // 10表示需要的斐波那契数列个数// 0// 1// 1// 2// 3 |
不使用全局变量,我把它们写在函数里了应该算是局部变量了吧,难道这样就好了?你怎么看?
5、实现如下语法的功能:var a = (5).plus(3).minus(6); //2
| 1 2 3 4 5 6 7 8 9 10 | Number.prototype.plus = function(a) { return this + a;};Number.prototype.minus = function(a) { return this - a;};var a = (5).plus(3).minus(6);console.log(a); // 2 |
直接在Number对象上加扩展方法即可,传说中这样很不好,but我也想不到更好的办法了...
6、实现如下语法的功能:var a = add(2)(3)(4); //9
| 1 2 3 4 5 6 7 8 9 10 11 | function add(a) { var temp = function(b) { return add(a + b); } temp.valueOf = temp.toString = function() { return a; }; return temp;}var ans = add(2)(3)(4);console.log(ans); // 9 |
对valueOf和toString的考察,具体可以参考《valueOf和toString》
另看到一种很飘逸的写法(来自Gaubee):
| 1 2 3 4 5 6 7 8 | function add(num){ num += ~~add; add.num = num; return add;}add.valueOf = add.toString = function(){return add.num};var ans = add(3)(4)(5)(6); // 18alert(ans);
|