js 数组扩充函数

javascript提供了一套数组可用的方法。这些方法是被储存在Array.prototype中的函数。这是可以被扩充的。

举例来说,假设我们想要给array增加一个方法,它允许我们对数组进行计算:

Array.method('reduce',function(f, value){
    var i;
    for(i=0;i < this.length;i+=1){
            value=f(this[i], value);
    }
    return value;
});

↑详见 javascript扩充类型功能

通过给Array.prototype扩充一个函数,每个数组都继承了这个方法。在这个例子里,我们定义了一个reduce方法,它接受一个函数和一个初始值作为参数。它遍历这个数组,以当前元素和该初始值为参数调用这个函数,并且计算出一个新值。当完成时,它返回这个值。如果我们传入一个把两个数字相加的函数,它会计算出相加之和。如果我们传入把两个数字相乘的函数,它会计算两者的乘积:

//创建一个数字数组
var data = [4,8,15,16,23,42];
//定义两个简单的函数。一个是把两个数字相加,另一个是把两个数字相乘
var add = function (a,b){
    return a + b;
};
var mult = function(a,b){
    return a * b;
};
//调用data的reduce方法,传入add函数
var sum = data.reduce(add,0);       //sum is 108
//再次调用reduce方法,这次传入mult函数
var product = data.reduce(mult,1);
//product = 7418880

因为数组其实就是对象,所以我们可以直接给一个单独的数组添加方法:

//给data数组添加一个total方法
data.total = function(){
    return this.reduce(add,0);
};
total = data.total();       //total = 108
※摘抄自《JavaScript语言精粹(修订版)》

猜你喜欢

转载自blog.csdn.net/baidu_24563939/article/details/80498783
今日推荐