while循环中的Javascript同步超时

时间:2012-06-19 14:37:41

标签: javascript asynchronous timeout while-loop synchronous

我正在尝试在执行AJAX请求时伪造同步JavaScript。 我有一个getPagePath(id)函数需要通过为页面ID提供页面路径来获取页面的页面路径,它通过Web API接收数据。我认为这很简单,只需对服务器执行ajax请求并接收页面路径。但是发生了什么:在请求页面路径时,我的代码继续运行并返回一个空的var,之后ajax调用结束,但是迟到了。

我知道我的解释并不多,所以这是我的代码:

var getPagePath = function() {

    // Function to check if this.pagePath is set.
    var pagePathReady = function() {
        console.log('PAGEPATH: CHECKING');
        if (this.pagePath && this.pagePath != null) {
            return true;
        } else {
            return false;
        }
    };

    if (!pagePathReady()) {
        // No pagePath defined so lets set it.
        this._setPagePath();

        while (!pagePathReady())
        {
            // Not yet defined, check again..

            // *** The problem ***
            // This while loop is running insanely fast making the browser crash.
            // How can I make this wile loop pause for 1 sec?
            // *******************

            console.log('PAGEPATH: NOT READY -> CHECK AGAIN');
        }

        // READY
        console.log('PAGEPATH: READY -> VALUE: ' + this.pagePath);
        return this.pagePath;
    } else {
        return this.pagePath;
    }
};

var _setPagePath = function() {
    if (!this.pagePathRequestFired) {
        this.pagePathRequestFired = true;
        // Fire request.
        system.url(
            this.getNodeId(), 
            function(url) {
                // Request ready, set pagePath.
                this.pagePath = url;
                this.pagePathRequestFired = false;
            }, 
            this
        );
    } else {
        // Call already running..
    }
};

我在更多解释性评论中设置了问题。

提前致谢!

2 个答案:

答案 0 :(得分:1)

而不是轮询pagePath(似乎不需要恕我直言)为什么不在_setPagePath准备就绪时执行回调?如果要伪造同步请求,只需将加载微调器作为叠加层显示给用户,从而禁用UI。

答案 1 :(得分:1)

如果确实需要,可以使ajax调用同步。

xmlhttp.open("GET", "url", false);

注意第3个参数。

但是,我认为您只需要编写代码来练习事件/回调概念。