5道 JavaScript 练习题

深切明白JavaScript系列(20):《你真懂JavaScript吗?》答案详解中末了的看到的一些演习题,并尝试本身做且记录下来。

找出数字数组中最大的元素(运用Math.max函数)

var arr = [61, 22, 31, 4, 5];
// 1
var max = 0;
arr.map(function (value, index) {
  max = Math.max(value, max);
});
// 2
Math.max.apply(null, arr)

转化一个数字数组为function数组(每一个function都弹出响应的数字)

var arr = [61, 22, 31, 4, 5];
var arr2 = arr.map(function (value, index) {
  return function () {
    alert(value);
  };
});

给object数组举行排序(排序前提是每一个元素对象的属性个数)

var arr = [
  {a:1, c:2, d:3, f:5, e:2},
  {a:1},
  {a:1, b:2, c: 3},
  {a:1, b:2}
];

function objectSort(a, b) {
 var num1 = 0, num2 = 0;
  
 for (var i in a) {
   num1 += 1;
 }
 for (var j in b) {
   num2 += 1;
 }
  
  return num1 < num2 ? -1 : 1;
}

应用for in轮回来提取对象属性的个数,而且保存在变量中。接着在对变量举行大小推断。

应用JavaScript打印出Fibonacci(斐波那契)数(不运用全局变量)

var fibonacci = (function () {
    var arr = [0, 1];
    return function () {
        var num = arr[arr.length - 1],
            len = arr.length;
        arr.push(arr[len - 1] + arr[len - 2]);
        return num;
    };
}());

//test
var i;
for (i = 0; i < 10; i++) {
    console.log(fibonacci());
}
//1,1,2,3,5,8,13,21,34,55

来自:Javascript Fibonacci using Closures

完成以下语法的功用:var a = (5).plus(3).minus(6); //2

Number.prototype.plus = function (num) {
  return this + num;
};
Number.prototype.minus = function (num) {
  return this - num;
};

完成以下语法的功用:var a = add(2)(3)(4); //9

function add(x) {
  return function (y) {
    return function (z) {
      return x + y + z;
    };
  };
}

总结一下:除了斐波那契那道题是写不出来,其他的都基本上没有问题,问题是良久之前的,在一个外洋的博客上面也见到,但是有轻微的修改。很合适进阶的jser来做演习。

    原文作者:_我已经从中二毕业了
    原文地址: https://segmentfault.com/a/1190000003850052
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞