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 返回一个 Promise 并在解决 deferred 时将 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 );
});