我在这里看了很多关于克隆和复制javascript对象的帖子,特别是这两个主题:
> How do I correctly clone a JavaScript object?
> What is the most efficient way to deep clone an object in JavaScript?
不过,这似乎对我不起作用.
这是我正在使用的一段代码:
var copiedobject = {};
$.getJSON(URL, null, function (data) {
copiedobject = jQuery.extend(true, {}, data);
});
console.log(JSON.stringify(copiedobject));
如果我在JSON调用中有我的控制台日志功能,它会输出正确的值,但在函数之后,它会被清空,并输出{}.
我尝试过使用copiedobject = JSON.parse(JSON.stringify(data)),以及“在Javascript中复制一个对象”帖子中的clone(obj)函数,都无济于事.
我错过了什么吗?
解决方法:
$.getJSON触发一个Ajax请求,默认情况下运行asyncronous.您的console.log将在请求完成之前触发.通过将控制台输出移动到回调中来修复它.
$.getJSON(URL, null, function (data) {
copiedobject = jQuery.extend(true, {}, data);
console.log(JSON.stringify(copiedobject));
});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。