在本文末尾的代码中,变量pPrice
是通过定义的
$(addProduct).attr(attrProductPrice);
然后通过JSON调用设置
$.getJSON(url, function(data) { console.log(data); pPrice = data.price; });
但在同步.getJSON
调用之后,该值已返回其原始值。
如何通过.getJSON
调用覆盖词法范围变量定义的定义?源代码缩写为相关部分:
function addToCart(i,qty){
var pPrice = $(addProduct).attr(attrProductPrice); //original value
var url = '/pricefor/' + pId;
$.getJSON(url, function(data) { console.log(data); pPrice = data.price; }); // new value
console.log(pPrice); // new value lost! back to original value?!
}
答案 0 :(得分:3)
getJSON
调用是异步的。在从服务器检索JSON之前,不会调用您的函数。时间表如下所示:
var pPrice = $(addProduct).attr(attrProductPrice);
var url = '/pricefor/' + pId;
$.getJSON(url, blah blah);
console.log(pPrice);
# some time later, when the server responds, your function is called.
console.log(data); pPrice = data.price;