JS前端文件讀取FileReader操作方法總結(jié)
FileReader
FileReader 是一個(gè)對(duì)象,允許 Web 應(yīng)用程序異步讀取存儲(chǔ)在用戶計(jì)算機(jī)上的文件(或原始數(shù)據(jù)緩沖區(qū))的內(nèi)容,使用 File 或 Blob 對(duì)象指定要讀取的文件或數(shù)據(jù)。
構(gòu)造函數(shù):
let reader = new FileReader(); // 沒(méi)有參數(shù)
主要方法
readAsArrayBuffer(blob)
將數(shù)據(jù)讀取為二進(jìn)制格式的 ArrayBuffer。當(dāng)讀取操作完成時(shí),readyState 變成 DONE(已完成),并觸發(fā) loadend 事件,同時(shí) result 屬性中將包含一個(gè) ArrayBuffer 對(duì)象以表示所讀取文件的數(shù)據(jù)。
reader.readAsArrayBuffer(blob)
readAsText(blob, [encoding])
將數(shù)據(jù)讀取為給定編碼(默認(rèn)為 utf-8 編碼)的文本字符串。
instanceOfFileReader.readAsText(blob[, encoding]);
readAsDataURL(blob)
讀取二進(jìn)制數(shù)據(jù),并將其編碼為 base64 的 data url。
reader.readAsDataURL(blob);
讀取方法都是異步的,也就是說(shuō)只有當(dāng)執(zhí)行完成后才能夠查看到結(jié)果,如果直接查看是無(wú)結(jié)果的,并返回 undefined。必須要掛載 實(shí)例下的 onload 或 onloadend 的方法才能處理轉(zhuǎn)化后的結(jié)果
FileReader的三個(gè)屬性:
- error: 返回讀取時(shí)的錯(cuò)誤信息
- readyState: 返回操作的當(dāng)前狀態(tài)
- result: 返回讀取文件的結(jié)果
讀取文件的示例:
參考 http://chabaoo.cn/javascript/3249569x8.htm
<input type="file" onchange="readFile(this)"> <script> function readFile(input) { let file = input.files[0]; let fileReader= new FileReader(); fileReader.readAsText(file); // 或者 fileReader.readAsArrayBuffer(file) /** * 該方法在讀取時(shí)調(diào)用 */ fileReader.onloadstart = () => { console.log("開(kāi)始讀取") console.log(fileReader.readyState)//調(diào)用函數(shù),但還沒(méi)有結(jié)束,返回1 } /** * 該方法在讀取成功時(shí)調(diào)用 */ fileReader.onload = () => { console.log("讀取成功") console.log(fileReader.result) console.log(fileReader.readyState)//調(diào)用完成,返回2 } /** * 該方法在讀取結(jié)束時(shí)調(diào)用 */ fileReader.onloadend = () => { console.log("讀取結(jié)束") } /** * 讀取過(guò)程中觸發(fā) */ fileReader.onprogress = (e) => { console.log("讀取中") //獲取已經(jīng)加載的數(shù)據(jù)量 console.log("loaded==>" + e.loaded) } /** * 該方法在調(diào)用abort函數(shù)時(shí)觸發(fā) */ fileReader.onabort = () => { console.log("操作終止") } //當(dāng)讀取出現(xiàn)失敗時(shí)觸發(fā) fileReader.onerror = () => { console.log("出現(xiàn)錯(cuò)誤") console.log(fileReader.error) } } </script>
read 方法的選擇tips:
readAsArrayBuffer
—— 用于二進(jìn)制文件,執(zhí)行低級(jí)別的二進(jìn)制操作。對(duì)于諸如切片(slicing)之類(lèi)的高級(jí)別的操作,F(xiàn)ile 是繼承自 Blob 的,所以可以直接調(diào)用它們,而無(wú)需讀取。readAsText
—— 用于文本文件,當(dāng)我們想要獲取字符串時(shí)。readAsDataURL
—— 用于在 src 中使用此數(shù)據(jù),并將其用于img
或其他標(biāo)簽時(shí)。還有一種用于此的讀取文件的替代方案:
URL.createObjectURL(file)
。
示例:根據(jù)用戶傳入的圖片文件,來(lái)生成一個(gè)對(duì)應(yīng)的臨時(shí)url,并將臨時(shí)url作為src傳給img標(biāo)簽
<input type="file" id="file"> <img id="img"> let file = document.getElementById("file") let img= document.getElementById("img") file.addEventListener("change", (e) => { let fileList=e.target.files //先獲取一份文件 //這里獲取的才是File對(duì)象 let file = fileList[0] //因?yàn)閒ile也是Blob對(duì)象,所以直接傳入即可 img.src=URL.createObjectURL(file) })
主要事件
讀取過(guò)程中,有以下事件:
- loadstart —— 開(kāi)始加載。
- progress —— 在讀取過(guò)程中出現(xiàn),當(dāng)FileReader讀取數(shù)據(jù)時(shí),進(jìn)度事件會(huì)定期觸發(fā)。
- load —— 讀取完成時(shí)觸發(fā),沒(méi)有 error。
- abort —— 在中止讀取時(shí)會(huì)觸發(fā) abort 事件:例如程序調(diào)用 abort()。。
- error —— 出現(xiàn) error時(shí)觸發(fā)。
- loadend —— 讀取完成,無(wú)論成功還是失敗。
讀取完成后,可以通過(guò)以下方式訪問(wèn)讀取結(jié)果:
- reader.result 是結(jié)果(如果成功)
- reader.error 是 error(如果失?。?。
檢測(cè)瀏覽器對(duì) FileReader 的支持:
if(window.FileReader) { var fr = new FileReader(); // add your code here }else { alert("Not supported by your browser!"); }
React + antd Upload 組件示例
場(chǎng)景: 表單文件上傳,讀取后以base64格式與表單一起傳給后端。
<Upload maxCount={1} accept=".jpg,.jpeg,.png" beforeUpload={(file) => { console.log('文件類(lèi)型', file.type, file); // 限制文件類(lèi)型 const allowTypes = [ 'image/png', 'image/jpeg', 'image/jpg', ]; const isAllowType = allowTypes.includes(file.type); // 校驗(yàn)文件大小和類(lèi)型 if (!isAllowType || file.size / 1024 / 1024 > 4) { message.error('文件格式大小錯(cuò)誤'); return Upload.LIST_IGNORE; } const reader = new FileReader(); //將上傳的文件讀取成base64 reader.readAsDataURL(file); reader.onloadend = function () { console.log('文件Base64內(nèi)容',reader.result, file); }; // 阻止上傳,為了最后和表單一起提交 return false; }} > <Button icon={<UploadOutlined />} type="primary"> 文件上傳 </Button> </Upload>
總結(jié)
到此這篇關(guān)于JS前端文件讀取FileReader操作方法總結(jié)的文章就介紹到這了,更多相關(guān)JS前端文件讀取FileReader內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript將字符轉(zhuǎn)換為ASCII碼的實(shí)現(xiàn)方法
在Web前端開(kāi)發(fā)中,字符編碼是處理文本數(shù)據(jù)時(shí)不可或缺的一部分,ASCII是一種廣泛使用的字符編碼標(biāo)準(zhǔn),它為每個(gè)字符分配了一個(gè)唯一的數(shù)字表示,解如何將字符轉(zhuǎn)換為ASCII碼,對(duì)于解析、生成和操作字符串具有重要意義,本文將詳細(xì)介紹這一過(guò)程,并提供多個(gè)實(shí)用的代碼示例2024-12-12使用JS中的exec()方法構(gòu)造正則表達(dá)式驗(yàn)證
這篇文章主要介紹了使用JS中的exec()方法構(gòu)造正則表達(dá)式驗(yàn)證的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08JavaScript實(shí)現(xiàn)LI列表數(shù)據(jù)綁定的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)LI列表數(shù)據(jù)綁定的方法,可實(shí)現(xiàn)綁定Li列表項(xiàng)對(duì)應(yīng)數(shù)值項(xiàng)的功能,涉及javascript鼠標(biāo)onmousemove、onmouseout及onclick等事件的相關(guān)使用技巧,需要的朋友可以參考下2015-08-08更優(yōu)雅的微信小程序骨架屏實(shí)現(xiàn)詳解
這篇文章主要介紹了更優(yōu)雅的微信小程序骨架屏實(shí)現(xiàn)詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-08-08js 賦值包含單引號(hào)雙引號(hào)問(wèn)題的解決方法
這篇文章主要介紹了js賦值包含單引號(hào)雙引號(hào)問(wèn)題的解決方法,需要的朋友可以參考下2014-02-02js 調(diào)用父窗口的具體實(shí)現(xiàn)代碼
想要實(shí)現(xiàn)如題所示:父窗體需要頂一個(gè)show()方法,具體實(shí)現(xiàn)代碼如下,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07javascript 瀏覽器檢測(cè)代碼精簡(jiǎn)版
javascript檢測(cè)瀏覽器精簡(jiǎn)版,需要的朋友可以參考下。2010-03-03Javascript點(diǎn)擊按鈕隨機(jī)改變數(shù)字與其顏色
這篇文章主要介紹了Javascript點(diǎn)擊按鈕隨機(jī)改變數(shù)字和其字體的顏色,實(shí)現(xiàn)后的效果很不錯(cuò),具有一定的參考價(jià)值,有需要的可以參考借鑒,下面來(lái)一起看看。2016-09-09