您的位置:首页 > Web前端 > JavaScript

javascript数组总结(0504)

2014-05-04 10:31 253 查看
一:数组复制

//方法一
//slice()函数将会返回一个新的数组对象
var arr = [1,2,3,4];
var clone = arr.slice(0);
arr.splice(1,2);//删除从位置1开始的两个元素
console.log("arr:" + arr + "\nclone:" + clone);//arr:[1,4] clone:[1,2,3,4]

//方法二:
//concat()用于多个数组的合并,但是返回的结果是一个新的数组,而不再引用用于合并的任何一个数组。可以利用它的这个特性来用一个数组连接空数组或直接不传参数完成clone的功能。
var arr = [1,2,3,4];
var clone = arr.concat();
arr.splice(1,2);//删除从位置1开始的两个元素
console.log("arr:" + arr + "\nclone:" + clone);//arr:[1,4] clone:[1,2,3,4]

//以上两种数组复制的操作都不适合对数组中包括复杂数据类型的数据,如果数组中包括复杂数据类型的数据,对这些数据的修改仍然会同时影响复制数组与被复制数组。所以它并不是一个彻底的能实现深层复制的处理思路。
var arr = [1,2,[1,2,3],4];
var clone = arr.slice(0);
arr[2].splice(1,1);//删除从位置1开始的两个元素
console.log("arr:" + arr + "\nclone:" + clone);//arr:[1,2,1,3,4] clone:[1,2,1,3,4]

//对象深层复制
Object.prototype.clone = function(){
var objClone;
if(this.constructor == Object){
objClone = new this.construtor();
}else{
objClone = new this.constructor(this.valueOf());
}
for(var key in this){
if(objClone[key]!=this[key]){
if(typeof(objClone[key] == "Object")){
objClone[key]=this[key].clone();
}else{
objClone[key] = this[key];
}
}
}
objClone.toString = this.toString;
objClone.valueOf = this.valueOf;
return objClone;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: