0

我试图在执行 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..
    }
};

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

提前致谢!

4

2 回答 2

1

与其轮询pagePath(恕我直言,这似乎不是必需的),为什么不在 _setPagePath 准备好时执行回调?如果你想伪造一个同步请求,你可以只向用户显示一个加载微调器作为覆盖,禁用 UI。

于 2012-06-19T14:44:47.200 回答
1

如果你真的需要,你可以同步 ajax 调用。

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

注意第三个参数。

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

于 2012-06-19T15:31:51.320 回答