今天看著這麼一段 程式碼 講淺拷貝
/* ================ 浅拷贝 ================ */
function simpleClone(initalObj) {
var obj = {};
for ( var i in initalObj) {
obj[i] = initalObj[i];
}
return obj;
}
/* ================ 客户端调用 ================ */
var obj = {
a: "hello",
b: {
a: "world",
b: 21
},
c: ["Bob", "Tom", "Jenny"],
d: function() {
alert("hello world");
}
}
var cloneObj = simpleClone(obj); // 对象拷贝
console.log(cloneObj.b); // {a: "world", b: 21}
console.log(cloneObj.c); // ["Bob", "Tom", "Jenny"]
console.log(cloneObj.d); // function() { alert("hello world"); }
// 修改拷贝后的对象
cloneObj.b.a = "changed";
cloneObj.c = [1, 2, 3];
cloneObj.d = function() { alert("changed"); };
console.log(obj.b); // {a: "changed", b: 21} // // 原对象所引用的对象被修改了
console.log(obj.c); // ["Bob", "Tom", "Jenny"] // 原对象所引用的对象未被修改
console.log(obj.d); // function() { alert("hello world"); } // 原对象所引用的函数未被修改
1、照道理講 淺拷貝 不是應該僅僅複製物件的引用,而不是物件本身,那麼 obj.c和obj.d都應該被修改了呀?
2、var cloneObj=obj ,算不算淺拷貝,怎麼理解?
ringa_lee2017-05-19 10:20:55
var cloneObj=obj // 这才是浅拷贝,改变这里会联动改变
// 这个方法不是浅拷贝,是一级深拷贝,二级拷贝是浅拷贝,因为obj[i] = initalObj[i];就相当于你的var cloneObj=obj 。
function simpleClone(initalObj) {
var obj = {};
for ( var i in initalObj) {
obj[i] = initalObj[i]; ////////注意这里 除非你递归赋值
}
return obj;
}
所以
cloneObj.a = "changed"; // obj不变
cloneObj.b.a = "changed"; // obj改变
高洛峰2017-05-19 10:20:55
存放物件的變數可以簡單的理解為一個位址,透過這個位址再去獲取其他子元素。 2. 對象的淺拷貝指的是新建一個對象,把他的子元素的值依序複製過去。 3. 因此拷貝後的物件雖然子元素值相同但是,做比較是不相等的,因為他們存放子元素變數的位址是不同的。 4.你的第二種方式是地址的直接賦值,沒有產生新的變量,或者說沒有產生新的創建子元素的地址,這就不叫拷貝。