如果你是用這種方式上傳的話(huà),確實(shí)沒(méi)有好方法。
成都創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的大方網(wǎng)站建設(shè)公司,大方接單;提供做網(wǎng)站、網(wǎng)站建設(shè),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行大方網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!
因?yàn)?XMLHttpRequest.onProgress 事件能拿到的是網(wǎng)絡(luò)傳輸?shù)淖止?jié)而已;你說(shuō)的問(wèn)題里,“上傳進(jìn)度已完成”,實(shí)際是指瀏覽器已經(jīng)把文件傳輸給了服務(wù)端;“很久才可以”,是你服務(wù)端額外處理的時(shí)間,這段時(shí)間對(duì)瀏覽器來(lái)說(shuō)是不可感知的,它怎么會(huì)知道你服務(wù)端處理需要多久呢?
一般處理思路有這么幾種:
1、上傳進(jìn)度設(shè)置一個(gè)最大值,比如 99%,只有當(dāng)服務(wù)端真正返回結(jié)果時(shí)才會(huì)變到 100%,這種方法最為簡(jiǎn)單粗暴;
2、盡量減少服務(wù)端處理的時(shí)間,例如收到文件后交給異步隊(duì)列去處理,立刻返回給客戶(hù)端響應(yīng),這種方法需要額外做的事件比較多,開(kāi)發(fā)難度更高一些;
3、客戶(hù)端分片上傳,把大文件變成若干段小“文件”,缺點(diǎn)是瀏覽器只有支持 HTML5 才支持 FormData 分片。
拖放支持:
可以從您的桌面或文件管理器中拖放他們?cè)谀臑g覽器窗口中上傳文件。
上傳進(jìn)度條:
顯示一個(gè)進(jìn)度條顯示為單獨(dú)的文件和所有上傳組合上傳進(jìn)度。
可取消上傳:
單個(gè)文件上傳可以取消來(lái)停止上傳進(jìn)度。
可恢復(fù)上傳:
中止的上傳可以與瀏覽器支持的Blob API進(jìn)行恢復(fù)。
分塊上傳:
大文件可以上傳較小的塊與瀏覽器支持的Blob的API 。
客戶(hù)端圖像大小調(diào)整:
圖像可以自動(dòng)調(diào)整大小的客戶(hù)端與瀏覽器支持所需的JS API的。
預(yù)覽圖像,音頻和視頻:
圖像,音頻和視頻文件的預(yù)覽可以與瀏覽器支持所需的API上傳前顯示。
前端要做的就是設(shè)置一個(gè)定時(shí)器通過(guò)接口去后臺(tái)獲取當(dāng)前上傳進(jìn)度是多少,然后渲染出進(jìn)度條就行。當(dāng)進(jìn)度達(dá)到100%時(shí)清除定時(shí)器。
ajax的表單提交只能提交data數(shù)據(jù)到后臺(tái),沒(méi)法實(shí)現(xiàn)file文件的上傳還有展示進(jìn)度功能,這里用到form.js的插件來(lái)實(shí)現(xiàn),搭配css樣式簡(jiǎn)單易上手,而且高大上,推薦使用。
需要解釋下我的結(jié)構(gòu), #upload-input-file 的input標(biāo)簽是真實(shí)的文件上傳按鈕,包裹form標(biāo)簽后可以實(shí)現(xiàn)上傳功能, #upload-input-btn 的button標(biāo)簽是展示給用戶(hù)的按鈕,因?yàn)樾枰獦邮降拿阑?。上傳完成生成的文件名將?huì)顯示在 .upload-file-result 里面, .progress 是進(jìn)度條的位置,先讓他隱藏加上 hidden 的class, .progress-bar 是進(jìn)度條的主體, .progress-bar-status 是進(jìn)度條的文本提醒。
去掉hidden的class,看到的效果是這樣的
[圖片上傳失敗...(image-2c700a-1548557865446)]
將上傳事件綁定在file的input里面,綁定方式就隨意了。
var progress = $(".progress-bar"), status = $(".progress-bar-status"), percentVal = '0%'; //上傳步驟 $("#myupload").ajaxSubmit({ url: uploadUrl, type: "POST", dataType: 'json', beforeSend: function () { $(".progress").removeClass("hidden"); progress.width(percentVal); status.html(percentVal); }, uploadProgress: function (event, position, total, percentComplete) { percentVal = percentComplete + '%'; progress.width(percentVal); status.html(percentVal); console.log(percentVal, position, total); }, success: function (result) { percentVal = '100%'; progress.width(percentVal); status.html(percentVal); //獲取上傳文件信息 uploadFileResult.push(result); // console.log(uploadFileResult); $(".upload-file-result").html(result.name); $("#upload-input-file").val(''); }, error: function (XMLHttpRequest, textStatus, errorThrown) { console.log(errorThrown); $(".upload-file-result").empty(); } });
[圖片上傳失敗...(image-3d6ae0-1548557865446)]
[圖片上傳失敗...(image-9f0adf-1548557865446)]
更多用法可以 參考官網(wǎng)
需要準(zhǔn)備的材料分別有:電腦、html編輯器、瀏覽器。
1、首先,打開(kāi)html編輯器,新建html文件,例如:index.html,并引入jquery。
2、在index.html中的script標(biāo)簽,輸入jquery代碼:
$('button').click(function () {
$('body').append('span正在上傳中/span');
setTimeout("$('span').text('上傳成功');", 1000);
});
3、瀏覽器運(yùn)行index.html頁(yè)面,點(diǎn)擊提交按鈕,顯示了“正在上傳中”。
4、例如過(guò)了1秒后變成了上傳成功的提示。