由于jQuery ajax调用,Bootstrap Modal没有立即加载点击按钮

时间:2015-05-29 12:48:42

标签: jquery cordova bootstrap-modal backbone-events jquery-ajaxq

当我正在进行ajax调用以根据statuscode返回的值验证URL时,我正在使用bootstrap模式来显示加载消息。一旦用户单击该按钮,就会显示一条加载器消息,并在后面的jQuery中调用ajax。

显示Bootstrap模式,但稍有延迟,我希望它立即显示Bootstrap模态加载器消息。

使用Bootstrap,backbone,jQuery。这基本上是使用网络技术开发的混合移动应用程序。

这是我正在做的事情,

BootStrap模态代码,基本上是隐藏的(我通过javascript打开模态)

<div class="modal fade bs-example-modal-lg" id="myModal" tabindex="-1" aria-hidden="true" data-backdrop="static" role="dialog">
    <div class="vertical-alignment-helper">
        <div class="modal-dialog modal-lg vertical-align-center">
            <div class="modal-content">
                <div class="modal-body">
                    <div id="gifLoad"><img id="loading-image" src="img/ajax-loader.gif" alt="Loading..." /> </div><div id="dataLoad"><p>Please wait..!!!</p></div>
                </div>
            </div>
        </div>
    </div>
</div>

按钮点击事件通过骨干

触发
   openPage: function () {  
        $('.modal').modal('show');         // Opening the bootstrap model on button click    
        var networkState = navigator.connection.type;
        if (networkState === Connection.NONE) {
            // Check the phone has internet connection or not to proceed further.
            var loaderView = SafetyLoaderView();
            loaderView.render();
            loaderView.appendMessage('Internet Connection seems to be offline');
            loaderView.show();
        }
        else {  
            var textValue = $('#inputValue').val();             // Get the entered value of the input box

            if (textValue === null || textValue === "") {
                $('.modal').modal('hide');
                // If the input box is empty then change the color of the border of thr input box.
                this.$el.find('#inputText').addClass('has-error');
            }
            else {

                var serverUrl = "https://www."+ value1 + value2  + "google.com";              // Forming the URL based on the values entered by the user.
                var status = this.validateURL(serverUrl);           // Calling the validateURL method to validate the URL.

                if (status === 200) {
                    $('.modal').modal('hide');
                    // If status code is equal to 200 opening the next screen of the application
                    var url = "page2.html";

                    window.location = url;
                }
                else if (status === -1) {
                    $('.modal').modal('hide');
                    var loaderView = new SafetyLoaderView();         // Handling the status code other than 200,400,404 and 500.
                    loaderView.render();                             // Displaying standard message to the remaining status code.
                    loaderView.appendMessage('The Request could not be completed');
                    loaderView.show();
                }
            }
        }
    },

验证URL方法,它也是骨干视图的一部分:

validateURL: function (url) {
        var stat = -1;         // Validating the URL. Based on the status code returned, appropriate error message is displayed.
        // New status code can be added to handle the message.

 //------------------------------------------------------------------------

        // ----------- I feel due to ajax call done here its giving me a delay to load modal
        // Instead I want instanly, if I use alert box that is displayed immediately  

//------------------------------------------------------------------


        $.ajax(url, {
            async: false,
            statusCode: {
                200: function (response) {
                    stat = 200;
                },
                400: function (response) {
                    $('.modal').modal('hide');     // Hiding the modal
                    var loaderView = new SafetyLoaderView();
                    loaderView.render();
                    loaderView.appendMessage('The Request could not be understood');
                    loaderView.show();
                    stat = 400;
                },
                404: function (response) {
                    $('.modal').modal('hide');         // Hiding the modal
                    var loaderView = new SafetyLoaderView();
                    loaderView.render();
                    loaderView.appendMessage('Requested URL not found');
                    loaderView.show();
                    stat = 404;
                },
                500: function (response) {
                    $('.modal').modal('hide');        // Hiding the modal
                    var loaderView = new SafetyLoaderView();
                    loaderView.render();
                    loaderView.appendMessage('Internal server error');
                    loaderView.show();
                    stat = 201;
                },
            },
        });
        return stat;
    },

如果我不调用validateURL方法,则Bootstrap模态会立即加载。

我的问题是如何在ajax调用期间显示此加载器模式。

0 个答案:

没有答案