更新時間:2022-10-25 來源:黑馬程序員 瀏覽量:
IT就到黑馬程序員.gif)
Blob對象就是一個包含只讀原始數(shù)據(jù)的類文件對象,其實File類型就派生子Blob類型,并且擴(kuò)展了支持操作用戶本地文件的功能。Blob對象可以直接調(diào)用構(gòu)造函數(shù)來生成。
var fileParts=['<a>hey man</a>'];
var myBlob=new Blob(fileParts, { "type":"text/xml"}); Blob對象還支持slice()方法,用于對數(shù)據(jù)進(jìn)行切割:
var yourBlob=myBlob.slice(10,20);
File對象同樣繼承了Blob的slice()方法,可以利用此方法對File對象預(yù)先進(jìn)行分割,然后再讀取、上傳,最后在服務(wù)器端進(jìn)行組裝——異步上傳的原理就是這樣。如果再記住分割點,這樣即使網(wǎng)絡(luò)中途斷掉,也可以在下次傳輸時從斷點續(xù)傳。
除了都接受Blob和File對象,這些方法另外一個共同點是,由于JavaScript本身基于事件驅(qū)動,這些和平臺相關(guān)的方法都是異步方法。即調(diào)用時立即返回,讀取文件操作完成后再觸發(fā)相應(yīng)的load事件。
除了load事件,F(xiàn)ileReader對象還會調(diào)用這樣一些事件處理程序。
(1)onabort:當(dāng)讀取操作被終止時調(diào)用(調(diào)用abort方法)
(2)onerror:當(dāng)讀取操作發(fā)送錯誤時調(diào)用。
(3)onload:當(dāng)讀取操作成功完成時調(diào)用。
(4)onloadend:當(dāng)讀取操作完成時調(diào)用,不管是成功還是失敗,該處理程序在onload或者onerror后調(diào)用。
(5)onloadstart:當(dāng)讀取操作將要開始之前調(diào)用。
(6)onprogress:在讀取數(shù)據(jù)過程中周期性調(diào)用。該事件為最有用的事件,在加載較大的文件時,可以提供一個進(jìn)度條讓用戶知道當(dāng)前加載進(jìn)度,不讓用戶產(chǎn)生焦躁感。
1024首播|39歲程序員逆襲記:不被年齡定義,AI浪潮里再迎春天
2025-10-241024程序員節(jié)丨10年同行,致敬用代碼改變世界的你
2025-10-24【AI設(shè)計】北京143期畢業(yè)僅36天,全員拿下高薪offer!黑馬AI設(shè)計連續(xù)6期100%高薪就業(yè)
2025-09-19【跨境電商運(yùn)營】深圳跨境電商運(yùn)營畢業(yè)22個工作日,就業(yè)率91%+,最高薪資達(dá)13500元
2025-09-19【AI運(yùn)維】鄭州運(yùn)維1期就業(yè)班,畢業(yè)14個工作日,班級93%同學(xué)已拿到Offer, 一線均薪資 1W+
2025-09-19【AI鴻蒙開發(fā)】上海校區(qū)AI鴻蒙開發(fā)4期5期,距離畢業(yè)21天,就業(yè)率91%,平均薪資14046元
2025-09-19