我一生都无法弄清楚这一点。我知道 ajax 进行调用的异步方式存在一些问题,但仍然无法确定问题所在。我有这个:
$(document).ready(function() {
$('#address').blur(function() {
console.log("now processing address");
var add = $("#address").val();
console.log("address is: " + add);
var refAdd = processAddress(add);
console.log("refined addres is: " + refAdd);
});
});
然后我有我正在调用的 processAddress 函数(感谢 SO 上的另一篇文章)。问题是上面的最后一条语句将 refAdd 返回为未定义。这是为什么??
function processAddress(address){
var geocoder = new google.maps.Geocoder();
if (geocoder) {
geocoder.geocode({ 'address': address }, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
//console.log(results[0].geometry.location);
console.log(results[0].formatted_address);
console.log("latitude is: " + results[0].geometry.location_type);
}
else {
console.log("Geocoding failed: " + status);
//formatted_address = "Geocoding failed: " + status;
formatted_address = "failed"
}
});
}
}
很明显是一个异步问题,我可以看到输出的打印顺序;refAdd 应该最后打印,但不是。
now processing address
address is: 415 N Mathilda Ave, Sunnyvale
refined addres is: undefined
415 N. Mathilda Ave, Sunnyvale, CA, USA
latitude is: ROOFTOP