0

我的应用程序通过AJAX/JSONP加载HTMLJavaScript ,而不是通过标准方式加载页面。它在iframe中工作,因此,这是与父Frame保持通信的正确方式(Safari限制)。

我必须提出 2 个请求:为自定义页面加载JavaScriptHTML。为了确保一切正常,我可以先加载JavaScript,然后加载HTML(在JavaScript onload 回调中)。但我希望同时发送这两个请求。

我准备了代码。当JavaScriptHTML都已加载时,脚本必须调用_finishLoading() 。函数_finishLoading()是否可能不会在浏览器中执行?

 function Loader()
 {
       this.load = function()
       {
                    // ...some code here...

        var this_ = this;

        var jsLoaded = false;
        var htmlLoaded = false;

        $.ajax(
            url: newUrl,
            dataType: "jsonp",
            jsonpCallback:
                function()
                {
                    $.ajax(
                        url: someUrl,
                        dataType: "html",
                        success:
                            function( data )
                            {
                                $( '#' + contentElId ).html( data );

                                if( htmlLoaded )
                                {
                                    this_._finishLoading()
                                }

                                jsLoaded = true;
                            }
                    );
                }
        );

        $.ajax(
            {
                url: someUrl2,
                dataType: "html",
                success:
                    function( data )
                    {
                        $( '#' + contentElId ).html( data )

                        if( jsLoaded )
                        {
                            this_._finishLoading()
                        }

                        htmlLoaded = true;
                    }
            }
        );
    }

}

更新

我需要加载 JavaScript、HTML,然后调用 onload() 来初始化加载的 Javascript。如果您知道更方便的方法,请单独加载它们,请告诉我

4

1 回答 1

1

考虑使用$.when()函数

代码将是这样的:

        var this_ = this;

        var jsLoaded = false;
        var htmlLoaded = false;
        var deferred = $.Deferred();
        $.ajax(
            url: newUrl,
            dataType: "jsonp",
            jsonpCallback:
                function()
                {
                    $.ajax(
                        url: someUrl,
                        dataType: "html"
                        success: function(){
                           deferred.resolve();
                        }
                    );
                }
        );

        var promise2 = $.ajax(
            {
                url: someUrl2,
                dataType: "html",
            }
        );

        $.when(deferred, promise2).done(function(a1, a2){
           $( '#' + contentElId ).html(a1);
           $( '#' + contentElId ).html(a2);
           this_._finishLoading()
        });
于 2013-07-13T11:27:40.907 回答