data
是覆盖results
,刚过results
已返回。
可以使用ajax
函数而不是getJSON
,因为getJSON
仅仅是
$.ajax({
url: url,
dataType: 'json',
data: data,
success: callback
});
速记,然后也设置async
到false
,使调用将阻塞。
但是,在你的情况下,这将无法正常工作,因为JSONP请求(与"?callback=?"
)不能同步。
其他(更好)选项是让任何代码依赖results
返回值被success
回调调用。
所以,与其是这样的:
var results = ajax.get.venues('search');
$('#results').html(translateResults(results));
也许是这样的:
ajax.get.venues('search', function (results) {
$('#results').html(translateResults(results));
});
venues = function (search, callback) {
$.getJSON("http://x.com/some.php?term="+search+"&callback=?",
function(data){
callback(data);
});
};
不是范围问题。您需要了解异步代码和回调是如何工作的。见例如。 http://stackoverflow.com/questions/2021114/javascript-jquery-variables-not-giving-expected-values,http://stackoverflow.com/questions/1092563/scope-of-variable-in-javascript-problem for其他人陷入同一陷阱。 – bobince 2010-09-14 15:26:11