ajax是异步的,你的代码会在ajax请求完成之前返回。 有几种方法可以重构代码。
您可以传递一个回调函数,一旦请求完成就会执行回调函数。
function getSearch(url, callback) {
$.getJSON(url, function(data) {
var out = '';
// btw what is numResults ??
for(var i = 0; i < numResults; i++) {
out += '<p class="hash_list">' + '<a href="http://www.twitter.com/' + data.results[i].from_user + '">' + data.results[i].from_user + '</a>: ' + data.results[i].text + '</p>';
}
if(typeof callback === 'function') callback(out);
});
}
然后,你会使用这样的功能。
getSearch('test.php', function(out){
// here you can use the out variable
});
或者你可以使用jQuery deferreds返回一个承诺,并通过out变量,当您解决延迟参数的一部分。这里是一个例子
function getSearch()
{
var deferred = $.Deferred();
$.getJSON(url, function(data) {
var out = '';
// btw what is numResults ??
for(var i = 0; i < numResults; i++) {
out += '<p class="hash_list">' + '<a href="http://www.twitter.com/' + data.results[i].from_user + '">' + data.results[i].from_user + '</a>: ' + data.results[i].text + '</p>';
}
deferred.resolve(out); // resolve the request and pass in the out argument.
});
return deferred.promise(); // return a promise
}
$.when(getSearch()).then(function(out){ // the out variable will get passed in
console.log(out);
});
你的JSON看起来是怎样的? – Shyju
欢迎来到** async **的精彩世界!你不能那样做。 – SLaks
@SLaks - 有关解决方法的任何想法? – callmecavs