码迷,mamicode.com
首页 > 编程语言 > 详细

javascript数组总结(0504)

时间:2014-05-04 20:41:11      阅读:309      评论:0      收藏:0      [点我收藏+]

标签:style   java   color   javascript   strong   string   

一:数组复制

//方法一
//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;
}

javascript数组总结(0504),布布扣,bubuko.com

javascript数组总结(0504)

标签:style   java   color   javascript   strong   string   

原文地址:http://www.cnblogs.com/peng14/p/3706212.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!