欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS前端文件讀取FileReader操作方法總結

 更新時間:2024年08月07日 09:39:25   作者:yqdidy  
FileReader?包含了一套完整的事件模型,用于捕獲讀取文件時的狀態(tài),下面這篇文章主要給大家介紹了關于JS前端文件讀取FileReader操作方法的相關資料,需要的朋友可以參考下

FileReader

FileReader 是一個對象,允許 Web 應用程序異步讀取存儲在用戶計算機上的文件(或原始數據緩沖區(qū))的內容,使用 File 或 Blob 對象指定要讀取的文件或數據。

構造函數:

let reader = new FileReader(); // 沒有參數

主要方法

readAsArrayBuffer(blob)

將數據讀取為二進制格式的 ArrayBuffer。當讀取操作完成時,readyState 變成 DONE(已完成),并觸發(fā) loadend 事件,同時 result 屬性中將包含一個 ArrayBuffer 對象以表示所讀取文件的數據。

reader.readAsArrayBuffer(blob)

readAsText(blob, [encoding])

將數據讀取為給定編碼(默認為 utf-8 編碼)的文本字符串。

instanceOfFileReader.readAsText(blob[, encoding]);

readAsDataURL(blob)

讀取二進制數據,并將其編碼為 base64 的 data url。

reader.readAsDataURL(blob);

讀取方法都是異步的,也就是說只有當執(zhí)行完成后才能夠查看到結果,如果直接查看是無結果的,并返回 undefined。必須要掛載 實例下的 onload 或 onloadend 的方法才能處理轉化后的結果

FileReader的三個屬性:

  • error: 返回讀取時的錯誤信息
  • readyState: 返回操作的當前狀態(tài)
  • result: 返回讀取文件的結果

讀取文件的示例:

參考 http://www.dbjr.com.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)
  
  /**
   * 該方法在讀取時調用
   */
  fileReader.onloadstart = () => {
      console.log("開始讀取")
      console.log(fileReader.readyState)//調用函數,但還沒有結束,返回1
  }
  /**
   * 該方法在讀取成功時調用
   */
  fileReader.onload = () => {
      console.log("讀取成功")
      console.log(fileReader.result)
      console.log(fileReader.readyState)//調用完成,返回2
  }
  /**
   * 該方法在讀取結束時調用
   */
  fileReader.onloadend = () => {
      console.log("讀取結束")
  }
  /**
   * 讀取過程中觸發(fā)
   */
  fileReader.onprogress = (e) => {
      console.log("讀取中")
      //獲取已經加載的數據量
      console.log("loaded==>" + e.loaded)
  }
  /**
   * 該方法在調用abort函數時觸發(fā)
   */
  fileReader.onabort = () => {
      console.log("操作終止")
  }
  //當讀取出現失敗時觸發(fā)
  fileReader.onerror = () => {
      console.log("出現錯誤")
      console.log(fileReader.error)
  }
}
</script>

read 方法的選擇tips:

  • readAsArrayBuffer —— 用于二進制文件,執(zhí)行低級別的二進制操作。對于諸如切片(slicing)之類的高級別的操作,File 是繼承自 Blob 的,所以可以直接調用它們,而無需讀取。
  • readAsText —— 用于文本文件,當我們想要獲取字符串時。
  • readAsDataURL —— 用于在 src 中使用此數據,并將其用于img 或其他標簽時。

    還有一種用于此的讀取文件的替代方案:URL.createObjectURL(file)。

示例:根據用戶傳入的圖片文件,來生成一個對應的臨時url,并將臨時url作為src傳給img標簽

<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對象
    let file = fileList[0]
    //因為file也是Blob對象,所以直接傳入即可
    img.src=URL.createObjectURL(file)
})

主要事件

讀取過程中,有以下事件:

  • loadstart —— 開始加載。
  • progress —— 在讀取過程中出現,當FileReader讀取數據時,進度事件會定期觸發(fā)。
  • load —— 讀取完成時觸發(fā),沒有 error。
  • abort —— 在中止讀取時會觸發(fā) abort 事件:例如程序調用 abort()。。
  • error —— 出現 error時觸發(fā)。
  • loadend —— 讀取完成,無論成功還是失敗。

讀取完成后,可以通過以下方式訪問讀取結果:

  • reader.result 是結果(如果成功)
  • reader.error 是 error(如果失敗)。

檢測瀏覽器對 FileReader 的支持:

if(window.FileReader) {
  var fr = new FileReader();
  // add your code here
}else {
  alert("Not supported by your browser!");
}

React + antd Upload 組件示例

場景: 表單文件上傳,讀取后以base64格式與表單一起傳給后端。

<Upload
  maxCount={1}
  accept=".jpg,.jpeg,.png"
  beforeUpload={(file) => {
    console.log('文件類型', file.type, file);
    // 限制文件類型
    const allowTypes = [
      'image/png',
      'image/jpeg',
      'image/jpg',
    ];
    const isAllowType = allowTypes.includes(file.type);
		// 校驗文件大小和類型
    if (!isAllowType || file.size / 1024 / 1024 > 4) {
      message.error('文件格式大小錯誤');
      return Upload.LIST_IGNORE;
    }
    const reader = new FileReader();
    //將上傳的文件讀取成base64
    reader.readAsDataURL(file);
    reader.onloadend = function () {
    	console.log('文件Base64內容',reader.result, file);
    };
    // 阻止上傳,為了最后和表單一起提交
    return false;
  }}
>
  <Button icon={<UploadOutlined />} type="primary">
    文件上傳
  </Button>
</Upload>

總結 

到此這篇關于JS前端文件讀取FileReader操作方法總結的文章就介紹到這了,更多相關JS前端文件讀取FileReader內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • JavaScript將字符轉換為ASCII碼的實現方法

    JavaScript將字符轉換為ASCII碼的實現方法

    在Web前端開發(fā)中,字符編碼是處理文本數據時不可或缺的一部分,ASCII是一種廣泛使用的字符編碼標準,它為每個字符分配了一個唯一的數字表示,解如何將字符轉換為ASCII碼,對于解析、生成和操作字符串具有重要意義,本文將詳細介紹這一過程,并提供多個實用的代碼示例
    2024-12-12
  • 使用JS中的exec()方法構造正則表達式驗證

    使用JS中的exec()方法構造正則表達式驗證

    這篇文章主要介紹了使用JS中的exec()方法構造正則表達式驗證的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-08-08
  • JavaScript實現LI列表數據綁定的方法

    JavaScript實現LI列表數據綁定的方法

    這篇文章主要介紹了JavaScript實現LI列表數據綁定的方法,可實現綁定Li列表項對應數值項的功能,涉及javascript鼠標onmousemove、onmouseout及onclick等事件的相關使用技巧,需要的朋友可以參考下
    2015-08-08
  • 更優(yōu)雅的微信小程序骨架屏實現詳解

    更優(yōu)雅的微信小程序骨架屏實現詳解

    這篇文章主要介紹了更優(yōu)雅的微信小程序骨架屏實現詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • js 賦值包含單引號雙引號問題的解決方法

    js 賦值包含單引號雙引號問題的解決方法

    這篇文章主要介紹了js賦值包含單引號雙引號問題的解決方法,需要的朋友可以參考下
    2014-02-02
  • js 調用父窗口的具體實現代碼

    js 調用父窗口的具體實現代碼

    想要實現如題所示:父窗體需要頂一個show()方法,具體實現代碼如下,感興趣的朋友可以參考下哈,希望對大家有所幫助
    2013-07-07
  • javascript 瀏覽器檢測代碼精簡版

    javascript 瀏覽器檢測代碼精簡版

    javascript檢測瀏覽器精簡版,需要的朋友可以參考下。
    2010-03-03
  • Javascript點擊按鈕隨機改變數字與其顏色

    Javascript點擊按鈕隨機改變數字與其顏色

    這篇文章主要介紹了Javascript點擊按鈕隨機改變數字和其字體的顏色,實現后的效果很不錯,具有一定的參考價值,有需要的可以參考借鑒,下面來一起看看。
    2016-09-09
  • nodejs入門詳解(多篇文章結合)

    nodejs入門詳解(多篇文章結合)

    Node.js是一套用來編寫高性能網絡服務器的JavaScript工具包,一系列的變化由此開始。比較獨特的是,Node.js會假設你是在POSIX環(huán)境下運行它Linux 或 Mac OS X
    2012-03-03
  • javascript常用功能匯總

    javascript常用功能匯總

    本文給大家總結了12個javascript常用的基本功能,十分的實用,這里推薦給大家,需要的朋友可以參考下
    2015-07-07

最新評論