首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何确保函数a在函数b..之前运行?

如何确保函数a在函数b..之前运行?
EN

Stack Overflow用户
提问于 2013-02-25 17:36:07
回答 1查看 92关注 0票数 1

我在使用下面的javascript代码时遇到了一些问题。

代码语言:javascript
运行
复制
        var returnValue = false;
        function hasItem(id) {
            //I want this entire function to run first
            db.transaction(function(tx) {
                tx.executeSql("SELECT * FROM library WHERE id == "+id,[],function(tx, results) {
                    returnvalue = results.rows.length>0; 

                },errorCB);
            },errorCB,successCB);

            //then this
            return returnvalue;
        }

但是sql-function似乎是在一个单独的线程中运行,这使得该函数总是返回false。有没有办法“强迫等待”?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-02-25 17:37:17

有没有办法“强制等待”?

不是的。您必须做的是更改hasItem函数,使其接受提供信息的回调,而不是返回值。

不知道你的errorCBsuccessCB回调做了什么,这有点棘手,但大致是这样的:

代码语言:javascript
运行
复制
function hasItem(id, callback) {
    var returnValue = false;
    db.transaction(function(tx) {
        tx.executeSql("SELECT * FROM library WHERE id == "+id,[],function(tx, results) {
            returnValue = results.rows.length > 0; 
        },failed);
    },failed,function() {
        successCB();
        callback(returnValue);
    });

    function failed() {
        errorCB();
        callback(null); // Or whatever you want to use to send back the failure
    }
}

然后,不是这样,而是

代码语言:javascript
运行
复制
if (hasItem("foo")) {
    // Do something knowing it has the item
}
else {
    // Do something knowing it doesn't have the item
}

您可以这样使用它:

代码语言:javascript
运行
复制
hasItem("foo", function(flag) {
    if (flag) {
        // Do something knowing it has the item
    }
    else {
        // Do something knowing it doesn't have the item
        // (or the call failed)
    }
});

如果您想在回调中判断调用是否失败

代码语言:javascript
运行
复制
hasItem("foo", function(flag) {
    if (flag === null) {
        // The call failed
    }
    else if (flag) {
        // Do something knowing it has the item
    }
    else {
        // Do something knowing it doesn't have the item
    }
});
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15063898

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档