我是靠谱客的博主 心灵美小霸王,最近开发中收集的这篇文章主要介绍JS Array 方法 以及 实现 过程 汇总,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

熟悉了JS一些方法,你才能运营JS得心应手,这里给出一些常用方法以及实现过程

//splice
Array.prototype.splice =function(start,delLen,item){
var len =this.length;
start = start<0?0:start>len?len:start?start:0;
delLen=delLen<0?0:delLen>len?len:delLen?delLen:len;
var arr =[],res=[];
var iarr=0,ires=0,i=0;
for(i=0;i<len;i++){
if(i<start|| ires>=delLen)	arr[iarr++]=this[i];
else {
res[ires++]=this[i];
if(item&&ires==delLen){
arr[iarr++]=item;
}
}
}
if(item&&ires<delLen) arr[iarr]=item;
for(var i=0;i<arr.length;i++){
this[i]=arr[i];
}
this.length=arr.length;
return res;
};
Array.prototype.shift =function(){ if(!this) return[];return this.splice(0,1)[0];}
//分开添加,关键字shallow copy,如果遇到数组,复制数组中的元素
Array.prototype.concat = function(){
var i=0;
while(i<arguments.length){
if(typeof arguments[i] === 'object'&&typeof arguments[i].splice ==='function' &&!arguments[i].propertyIsEnumerable('length')){
// NOT SHALLOW COPY BELOW
//	Array.prototype.concat.apply(this,arguments[i++]);
var j=0;
while(j<arguments[i].length)	this.splice(this.length,0,arguments[i][j++]);
i++;
} else{
this[this.length]=arguments[i++];
}
}
return this;
}
Array.prototype.join=function(separator){
var i=0,str="";
while(i<this.length) str+=this[i++]+separator;
return str;
}
Array.prototype.pop = function() { return this.splice(this.length-1,1)[0];}
Array.prototype.push = function(){
Array.prototype.splice.apply(this,
[this.length,0].concat(Array.prototype.slice.apply(arguments))); //这里没有直接处理参数,而是复制了一下
return this.length;
}
Array.prototype.reverse = function(){
for(var i=0;i<this.length/2;i++){
var temp = this[i];
this[i]= this[this.length-1-i];
this[this.length-1-i] = temp;
}
return this;
}
Array.prototype.slice =function(start,end){
var len =this.length;
start=start<0?start+=len:start?start:0;
end =end<0?end+=len:end>len?len:end?end:len;
var i=start;
var res = [];
while(i<end){
res.push(this[i++]);
}
return res;
}
// sort is the
most horrible function
Array.prototype.sort=function(fn){
if (!(fn && typeof fn ==='function')) fn=function(a,b)
{	return a.toString()<b.toString()?-1:a.toString()>b.toString()?1:0;}
for(var i=0;i<this.length-1;i++)
for(var j=i;j<this.length;j++)
if(fn(this[i],this[j])==1){
var temp =this[i];
this[i]=this[j];
this[j]=temp;
}
return this;
}
//arr.unshift(ele1,ele2,ele3....)
Array.prototype.unshift =function(){
Array.prototype.splice.apply(this,[0,0].concat(Array.prototype.slice.apply(this,arguments)));
}


最后

以上就是心灵美小霸王为你收集整理的JS Array 方法 以及 实现 过程 汇总的全部内容,希望文章能够帮你解决JS Array 方法 以及 实现 过程 汇总所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(45)

评论列表共有 0 条评论

立即
投稿
返回
顶部