我创建了一个示例来向您展示我的问题所在。我将发布代码,然后解释。
我的JS:
$('#mybtn').on('click', function(){
//$(fn1).promise().done(fn2);
$.Deferred(fn1).then(fn2);
});
function fn1(){
console.log("1");
$.ajax({
url: 'ajax.php',
type: 'POST',
data: {
func: "1"
},
success: function(data){
console.log(data);
}
});
}
function fn2(){
console.log("2");
$.ajax({
url: 'ajax.php',
type: 'POST',
data: {
func: "2"
},
success: function(data){
console.log(data);
}
});
}
我的PHP:
<?php
$request = $_POST['func'];
switch ($request) {
case '1':
fn1();
break;
case '2':
fn2();
break;
}
function fn1(){
print "1";
sleep(4);
}
function fn2(){
print "2";
sleep(2);
}
?>
所以,我尝试用这两种方法调用函数并等待它们结束,第一种://$(fn1).promise().done(fn2);打印1,2,然后是2,1。第二个:$ .Deferred(fn1).then(fn2);打印1,1和停止,只是甚至不调用fn2,我想打印的是1,1,2,2。我可以解决在变量中返回ajax请求然后只使用promise()的问题。但我不能这样做,我需要等待功能而不改变它,这可能吗?我的意思是这样的:
toWait.someWayToWait().then(anotherFunctionToWait());
function toWait(){
//whatever code or functions in here.
fn1();
fn2();
fnX();
}
function anotherFunctionToWait(){
//whatever code or functions in here.
}
谢谢。
答案 0 :(得分:0)
没有。由于函数无法让调用者知道它何时完成,因此您无法等待它们完成。你需要以某种方式改变这个功能。
严格地说,它可以用monkeypatching来完成,但这是一种可怕的方式。