function jsoncall(){
$.getJSON("http://localhost:3000/data", function (data) {...});
$.getJSON("http://localhost:3000/data", function (data) {...});
}
jsoncall.callback(function(){
//do stuff
});
类似于上面的伪代码。 JavaScript中是否有一种方法可以将异步调用视为上面的getJSON
?
答案 0 :(得分:1)
使用延期:[https://api.jquery.com/jquery.deferred/][1]
function jsoncall(){
var $def = $.Deferred();
$.getJSON("http://localhost:3000/data", function (data) {
$def.resolve(data);
});
return $def;
}
jsoncall.done(function(data){
//do stuff
});
答案 1 :(得分:0)
如果你问我的想法,那么你需要在函数中实现callback
。
function jsonCall(callback) {
$.getJSON('http://localhost:3000/data', function(data) {
....
callback(data);
});
}
jsonCall(function(data) {
...
});
答案 2 :(得分:0)
创建一个utils.js并将你的ajax函数调用到需要的地方。
//utils.js
function doAjax(callbackFunc, method, url) {
var xmlHttpReq = new XMLHttpRequest();
xmlHttpReq.open(method, url);
xmlHttpReq.onreadystatechange = function() {
if (xmlHttpReq.readyState == 4 && xmlHttpReq.status == 200) {
callbackFunc(xmlHttpReq.responseText,buttonArrayInit);
}
}
xmlHttpReq.send(null);
}
function loadMyJson(categoryValue){
if(categoryValue==="veg")
doAjax(print,"GET","http://localhost:3004/vegetables");
else if(categoryValue==="fruits")
doAjax(print,"GET","http://localhost:3004/fruits");
else
console.log("Data not found");
}