javascript - 全局变量的值为何被改变了?

查看:93
本文介绍了javascript - 全局变量的值为何被改变了?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

var collection = {
    "5439": {
    "album": "ABBA Gold"
    }
};
function updateRecords(id, prop, value) {
  collection1 = collection;
  document.write("begin "+JSON.stringify(collection)+"</br>");
  collection1[id][prop]=value;
  document.write(JSON.stringify(collection1)+"</br>");
}
updateRecords(5439, "tracks", "Addicted to Love");
updateRecords(5439, "test", "my test");

为何结果是

begin {"5439":{"album":"ABBA Gold"}}
"5439":{"album":"ABBA Gold","tracks":"Addicted to Love"}}
begin {"5439":{"album":"ABBA Gold","tracks":"Addicted to Love"}}
{"5439":{"album":"ABBA Gold","tracks":"Addicted to Love","test":"my test"}}

不是

begin {"5439":{"album":"ABBA Gold"}}    
{"5439":{"album":"ABBA Gold","tracks":"Addicted to Love"}}    
begin {"5439":{"album":"ABBA Gold"}}    
{"5439":{"album":"ABBA Gold","test":"my test"}}

collection是全局变量,我在函数里面也仅仅是对局部变量collection1赋值,collection1的改变,为何影响到了collection?

解决方案

浅拷贝,经常犯的错误。因为原始对象和新对象引用的同一个内存地址,因此改变一个值就会改变另一个的值。
解决办法:

var b = JSON.parse(JSON.stringify(a));// 当然全部会转成String,带有function之类的对象就会有问题

Object.freeze(a);// 建议这个,好像怎么玩都可用
var b = a;

或jquery的extend,反正各种解决办法...

这篇关于javascript - 全局变量的值为何被改变了?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆