词法范围变量在getJSON调用中被覆盖后保留值

时间:2011-09-19 19:39:18

标签: javascript jquery variables getjson lexical

在本文末尾的代码中,变量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?!        
  }

1 个答案:

答案 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;