时间:2021-05-28
 复制代码 代码如下: 
/*!
* jLip JavaScript Library v0.1 
*
* Copyright 2012, Lip2up (lip2up@qq.com) 
* Just for free use, NO LICENSE 
*/
(function() { 
function extend(target, props) { 
for (var m in props) { 
if (target[m] === undefined) target[m] = props[m]; 
}
}
var fns = { every: 1, some: 2, forEach: 3, map: 4, filter: 5 }, 
reduceError = 'Reduce of empty array with no initial value'; 
function each(fn, _this, kind) { 
var len = this.length, ret = kind == fns.filter ? [] 
: kind == fns.map ? Array(len) : undefined, 
find = kind == fns.some, i, v; 
for (i = 0; i < len; i++) { 
if (this[i] !== undefined) { 
v = fn.call(_this, this[i], i, this); 
switch (kind) { 
case fns.every: 
case fns.some: 
if (v === find) return find; 
break;
case fns.map: 
ret[i] = v; 
break;
case fns.filter: 
if (v === true) ret[ret.length] = this[i]; 
break;
}
}
}
return kind >= fns.forEach ? ret : !find; 
}
function reduce(fn, init, right) { 
var len = this.length, i, prev, inc = right ? -1 : 1; 
if (len == 0 && init === undefined) 
throw TypeError(reduceError); 
for (i = right ? len - 1 : 0, prev = init; 
prev === undefined && (right ? i >= 0 : i < len); 
i += inc) { 
prev = this[i]; 
}
if (prev === undefined && i == (right ? -1 : len)) 
throw TypeError(reduceError); 
for (; (right ? i >= 0 : i < len); i += inc) { 
if (this[i] !== undefined) 
prev = fn(prev, this[i], i, this); 
}
return prev; 
}
extend(Array.prototype, { 
every: function(fn, _this) { 
return each.call(this, fn, _this, fns.every); 
},
some: function(fn, _this) { 
return each.call(this, fn, _this, fns.some); 
},
forEach: function(fn, _this) { 
return each.call(this, fn, _this, fns.forEach); 
},
map: function(fn, _this) { 
return each.call(this, fn, _this, fns.map); 
},
filter: function(fn, _this) { 
return each.call(this, fn, _this, fns.filter); 
},
reduce: function(fn, init) { 
return reduce.call(this, fn, init); 
},
reduceRight: function(fn, init) { 
return reduce.call(this, fn, init, true); 
}
});
})();
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言ES5中新增的不少东西,了解之对我们写JavaScript会有不少帮助,下面主要介绍了ES5中的Array对象,需要的朋友们一起来看看吧。一、创建Array
本文主要讲解ES6数组方法find()与findIndex(),关于JS的更多数组方法,可参考以下:①JavaScript内置对象之-Array②ES5新增数组
JavaScript1.6引入了几个新的Array方法,具体的介绍见:NewinJavaScript1.6。这些方法已经被写进了ECMA262V5。现代浏览器(
JavaScript中的Array类型是经常用到的,Array类型也提供了很多方法能实现我们需求,下面我们来总结一下一、创建Array的方法varcolors=
本文实例讲述了javascript自定义in_array()函数实现方法。分享给大家供大家参考。具体如下:functionin_array(what,where