繁体   English   中英

我如何在javascript中先调用函数然后再调用第二个函数

[英]How do i call a function first and then the second in javascript

我想打电话给checkifPresentInActiveProjLib第一和后功能checkifPresentInClosedProjLib function.How我实现这一点?

checkifPresentInActiveProjLib(function(flgAc) {
    if (flgAc === "active_found")
        // do something

    $.ajax(...); // ajax call
});

checkifPresentInClosedProjLib(function(flgCl) {
    if (flgCl === "closed_found")
        // do something

    $.ajax(...); // ajax call
});

只需使用Promise即可处理异步事件。 您需要修改checkifPresentInActiveProjLib以返回诺言,在这种情况下,您的诺言是$.ajax(...); 所以你确实return $.ajax(...); 然后只需按以下方式调用下一个func:

 checkifPresentInActiveProjLib(...)
.then(function() { 
      checkifPresentInClosedProjLib(args)
})

您可以使用javascript Promise对象

  function  checkifPresentInActiveProjLib(flgAc) {
    if (flgAc === "active_found")
        alert('active_found');
};

function checkifPresentInClosedProjLib(flgCl) {
    if (flgCl === "closed_found")
        alert('closed_found');
};

function makeAjaxCall(){
   var promiseObj = new Promise(function(resolve, reject){
         resolve(checkifPresentInActiveProjLib());
   });
 return promiseObj;
}

 makeAjaxCall().then(checkifPresentInClosedProjLib());

这两个函数中都有异步ajax调用。 如果要在第一个函数完成后调用第二个函数,则需要等待第一个函数完成。

您可以通过在第一个函数的ajax函数部分的response部分中调用第二个函数来简单地做到这一点。

checkifPresentInActiveProjLib(function(flgAc) {
    if (flgAc === "active_found")
        // do something

    $.ajax(...).done(function( data ) {
    // call second function here
  }););
});

或者您可以使用诺言:

checkifPresentInActiveProjLib(function (flgAc) {
    return new Promise(function (resolve, reject) {
        if (flgAc === 'active_found')
        // do something
        $.ajax(...)
                .done(function (data) {
                  if (data) resolve(data);
                })
                .fail(function (err) {
                  reject(err);
                });
    });
});

然后调用函数为:

checkifPresentInActiveProjLib(...).then(data => checkifPresentInClosedProjLib(...)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM