【发布时间】:2015-07-08 12:13:30
【问题描述】:
根据文档,jQuery.extend() 是执行 JSON 对象的深拷贝和浅拷贝的解决方案。但是,当我使用它时,我得到一个未定义的对象错误。
我的 ajax 请求函数和处理程序:
var tourData;
$.ajax({
type: "GET",
url: "includes/phpscripts.php?action=stops",
dataType: "json",
success: (function(data){
if (data == 'false')
console.log("Can't load initial panorama");
else
processOptions(data);
})
});
function processOptions(data){
tourData = jQuery.extend(true, {}, data);
console.log(data.length);
console.log(tourData.length);
}
在 Firebug 中,data.length 返回 6,这是我的预期。但是,tourData 返回未定义。无论有没有true 作为深拷贝的参数,都会发生这种情况
稍后我将需要此请求中的数据可用于多个函数,而这些函数将超出范围。因此,我想要一个可用的响应的克隆。
data的内容是
[
{"fileName":"..\/panos\/photos\/1-prefix_blended_fused.jpg","name":"Start","lat":"43.682211","lon":"-70.450705","heading":"250","width":"1808","height":"653"},
{"fileName":"..\/panos\/photos\/2-prefix_blended_fused.jpg","name":"Second","lat":"43.6822","lon":"-70.450769","heading":"250","width":"1600","height":"578"},
{"fileName":"..\/panos\/photos\/2-prefix_blended_fused.jpg","name":"Second","lat":"43.6822","lon":"-70.450769","heading":"250","width":"1600","height":"578"},
{"fileName":"..\/panos\/photos\/3-prefix_blended_fused.jpg","name":"Third Stop","lat":"43.682219","lon":"-70.450828","heading":"250","width":"1821","height":"627"},
{"fileName":"..\/panos\/photos\/4-prefix_blended_fused.jpg","name":"Fourth Stop","lat":"43.68218","lon":"-70.450887","heading":"250","width":"1600","height":"800"},
{"fileName":"..\/panos\/photos\/5-prefix_blended_fused.jpg","name":"Last Stop","lat":"43.682165","lon":"-70.450933","heading":"250","width":"1808","height":"673"}
]
【问题讨论】:
-
看来
data是一个数组。console.log(data),让我们看看里面有什么。 -
是的,数据是一个数组,而不是一个对象。你想让
$.extend在这里做什么?你想要的输出是什么? -
数据是一个 JSON 对象。我想复制它,以便它在 ajax 请求和处理程序范围之外可用。
-
tourData = data;?data是一个(对象)数组,而不是一个对象。 -
你不必为此使用深拷贝功能吗?