我想将网络表单转换为离线工作。最初,我会在用户完成每个步骤后将表单信息存储在 Web 服务器上的 SQL 数据库中。其中一个步骤包括上传图像,为此我实现了一个进度条。
添加服务工作者后,我注意到进度条不再起作用(进度条会显示,但永远不会更新以显示已上传的文件量)。我在多个浏览器中进行了测试,以确保这不依赖于浏览器,并且在所有浏览器(chrome、firefox、edge、safari、移动版本)中都有相同的结果。
这是我的 ajax 请求的第一部分。
$.ajax({
type: "POST",
url: url,
datatype: "json",
data: JSON.stringify(data),
xhr: function () {
var xhr = new window.XMLHttpRequest();
xhr.upload.addEventListener("progress", function (evt) {
if (evt.lengthComputable) {
var percentComplete = getCurrentProgress(evt.loaded, evt.total);
$("#progressBarContainer .progress > .progress-bar").css({ "width": percentComplete + "%" });
$("#progressBarContainer .progress > .progress-bar .percent-complete").text(percentComplete + "%");
}
}, false);
return xhr;
}
})
这是我的服务工作人员文件中用于处理获取事件的代码。
self.addEventListener("fetch", event => {
event.respondWith(
caches.open(staticCacheName)
.then(cache => {
return cache.match(event.request)
.then(response => {
if (response) {
return response;
}
else {
return fetch(event.request);
}
});
})
);
});
我能够找到解决方案,但在 stackoverflow 上找不到这个问题,所以我发布并回答我自己的问题。如果有人有任何改进意见或更好的解决方案,请告诉我。