[英]Wait for a function to finish before if()else()
我有这个:
var myError;
function getNames(user,location){
myError=null;
//Make an Ajax Call (this takes some time)
//On Success do this:
if(//Some Condition){
myError=false;
}else{
myError=true
}
}
function first(){
getNames(user, location);
if(myError==false){ //MYCONDITION
//do some custom stuff just for first();
}else{
alert("Failed");
}
}
function second(){
getNames(user, location);
if(myError==false){ //MYCONDITION
//do some custom stuff just for second();
}else{
alert("Failed");
}
}
现在,当我调用first()或second()时,它总是给我警报消息“ FAILED”。 问题在于/// MYCONDITION在getNames()函数完成之前正在执行。 我想等待getNames()执行,然后才能检查// MYCONDITION。
我无法设置延迟,因为我不知道getNames()将花费多少时间。 我正在考虑使用一些jQquery函数,但似乎找不到一个。
而且,我正在尝试使getNames()尽可能通用。 因此,我正在考虑一种不打扰getNames()的方法。
我看到的最后一个选项是将callback()添加到getNames()。 但是,该函数也被其他不需要回调()的函数调用。
有什么想法吗?
谢谢。
添加回调完全没问题; 您可以检查它是否存在:
function getNames(user, location, callback){
myError=null;
//Make an Ajax Call (this takes some time)
//On Success do this:
if(//Some Condition){
myError=false;
}else{
myError=true
}
if(callback) {
callback.apply();
}
}
如果由于通用性不够而困扰,则可以让该函数接受对象而不是参数,因此:
function getNames(options) {
var user = options.user;
var location = options.loacation;
var callback = options.callback;
myError=null;
//Make an Ajax Call (this takes some time)
//On Success do this:
if(//Some Condition){
myError=false;
}else{
myError=true
}
if(typeof callback !== "undefined") {
callback.apply();
}
}
当调用getNames
,您可以执行以下操作:
getNames({
user: "some user",
location: "some location",
callback: function() {
...
}
});
要么
getNames({
user: "some user",
location: "some location"
});
在jquery中,如果您不喜欢回调(我非常希望您不喜欢:)),那么您很幸运,我的朋友。 $ .ajax()函数中有一个标志,可用于关闭该特定AJAX请求的异步。 下面是代码示例:
http://api.jquery.com/jQuery.ajax/
var x = 1;
jQuery.ajax({
url: 'http://example.com/catalog/create/',
success: function(result) {
x = 59;
},
async: false
});
console.log(x); //Should print 59 instead of 1
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.