在进行ajax调用时,Kendo Progress bar不会启动

时间:2016-02-25 12:51:48

标签: javascript jquery ajax kendo-ui kendo-progressbar

我想为我的服务器端ajax调用实现Kendo进度条。   我试过但是它没有在ajax调用之前启动,如果我使用下面的setTimeOut函数来关闭ajax调用,则进度条仅显示一小段时间。   例如:

 setTimeout ( function() 
       {
        kendo.ui.progress($("#progressBar"), false); //close the progress bar       
       },5000);

在上面的代码中,进度条仅显示5000毫秒,然后关闭。这是我的实际要求。

我需要两个ajax调用,一个在另一个内部。我想在第一个ajax调用启动之前实现进度条,并希望在第二个ajax调用完成后关闭。       另一个选择是在第一个ajax调用启动之前实现进度条,并在第一个调用完成后关闭它,然后启动第二个ajax调用的进度条,并在第二个ajax调用完成时关闭。

我希望我的要求是明确的。如果您需要更多详细信息,请告诉我们。这是我的代码:

 <div id="progressBar"></div>

   <script> 
        var getResponseFromSOA = function(filterObject, file,verb, callback) {      
    createFilterString(filterObject, function(filterString) {// get the filter string
        if(jQuery) {// check the jQuery file is integrated or not
            var headers = {Authorization: COOKIES.readCookie("Authorization"),requestmode:"ACK_URL"};
            headers.isRender = file.isRender;
            if(file.inputDataHeaders)
                headers.inputData = file.inputDataHeaders;
            /*
             * Since it is async call that's why call will be 2 times.
             * 1st time we have to call to the request handler of the SOA.
             * In the response we will get one link address of response handler.
             * 2nd time we have to call that link what we got from the 1st request.
             * Response handler will give actual data in the data property of the response
             */

                    kendo.ui.progress($("#progressBar"), true); //Here progress bar will initiate

                jQuery.ajax({
                    url: file.fileUrl + "/" + $securityComponent.cryptograghicFunctions.encryptor(filterString),
                    type: verb,
                    headers: headers,
                    async: false,
                    error : function()
                    {
                        console.log("some error occured at getResponseFromSOA submitting the request");
                    },
                    success: function(responseDataFromRequestHandler) {                         
                        // again call because it is async mode form SOA team
                        jQuery.ajax({
                            url: responseDataFromRequestHandler.links[1].href,
                            async: false,
                            headers: {Authorization: COOKIES.readCookie("Authorization"),requestmode:"ACK_URL"},
                            success: function(responseDataFromResponseHandler) {
                                try {
                                    console.log(responseDataFromResponseHandler);
                                    if(callback) callback(responseDataFromResponseHandler.data);
                                }catch(e) {
                                    console.log(responseDataFromResponseHandler);
                                    // printing the error message in the console window
                                    console.log("Error in the callback in data-transactor-js > getResponseFromSOA"
                                            + "\n"
                                            + e.message);
                                }
                            },                          
                            complete: function() {

                                    kendo.ui.progress($("#progressBar"), false); //close the progress bar       

                            }
                        });
                    },
                    complete: function() {                          
                            kendo.ui.progress($("#progressBar"), false); //close the progress bar       

                    }
                });


        } else throw {message: "jQuery is not defined or jQuery file is not linked"};
    });
};

</script>

提前致谢...

1 个答案:

答案 0 :(得分:1)

这里有一些事情 1. Kendo依赖于JQuery,但您在JQuery处理程序初始化之前尝试初始化进度窗口小部件。始终将Kendo代码放在JQuery处理程序中,并确保在Kendo脚本之前包含对JQuery库的引用。

<script>
$(function ()
{
    kendo.ui.progress($("#progressBar"), true);

    // Make your ajax call here
}

2。确保您的汇总代码在每个可能的代码路径中关闭进度条,否则它将无限期运行,您的用户将无法继续。在您的示例中,您在第二次调用的Complete处理程序中有kendo.ui.progress($("#progressBar"), false,但不是第一次调用。如果用户在第一次通话时收到错误,则进度条将永远不会关闭。

3.您在代码中禁用了异步模式,但您的评论让我觉得您不是故意的。 async:false在这里是不必要的,因为你在第一次成功的时候进行了第二次AJAX调用。通过这种方式,您可以自己控制呼叫的执行顺序。

4.我想你已经知道了,但是在任何类型的进度指示器上设置预定义的超时值并不是一个好主意,因为你无法知道这个过程需要多长时间。