3

我正在使用blueimp 文件上传插件来实现一些文件上传功能,我注意到在我的最后一个文件进度条达到 100% 和停止和完成事件触发之间可能会有很大的时间间隔。我有以下代码:

        $('#fileupload').fileupload({
            dataType: 'json',
            progress: function (e, data) {
                var progress = parseInt(data.loaded / data.total * 100, 10);
                var bar = data.context.children().children(".progress");
                $(bar).css("width", progress + "%");
            },
            add: function (e, data) {
                data.context = $("<div></div>").html("Uploading...<div class='progressHolder'><div class='progress'>&nbsp;</div></div>").appendTo($("#files"));
                data.submit();
                $("#processing").fadeIn();
            },
            stop: function (e, data) {
                $("#uploadFiles").fadeIn();
                $("#processing").fadeOut();
            },
            done: function (e, data) {
                $.each(data.result.files, function (index, file) {
                    idArray.push(file.Id);
                });
            }
        });

有谁知道为什么会发生这种情况?我怎样才能做到这一点,以便在调用完成/停止时考虑进度条?

4

1 回答 1

7

当您上传文件时,文件首先(显然)上传到服务器,然后服务器将执行请求的服务器端脚本,然后您在其中处理文件。如果请求的“处理文件”部分不是即时的,则在进度达到 100% 和触发完成回调之间会有延迟。如果有网络延迟,也可能会有延迟。

progress 事件只跟踪上传的进度,而不是请求的进度。

一种解决方案是让您的进度条停在 say 处,90%然后100%在 done 回调中将其撞到。data.total简单地乘以1.1

        progress: function (e, data) {
            var progress = parseInt(data.loaded / (data.total*1.1) * 100, 10);
            var bar = data.context.children().children(".progress");
            $(bar).css("width", progress + "%");
        },
于 2013-02-04T16:52:57.280 回答