vue 圖片轉base64格式方法總結


直入主題,上代碼(其實用的還是FileReader)
主要方法

handleRemove(file, fileList) {
      console.log(file); 
      
      var reader = new FileReader();
      reader.readAsDataURL(file.raw); // 一定要傳入file格式 
      reader.onload = () => {
        console.log("file 轉 base64結果:" + reader.result);
      };
      reader.onerror = function(error) {
        console.log("Error: ", error);
      };
},

vue組件

<!--  -->
<template>
  <div>
    <el-upload
      class="upload-demo"
      action="https://jsonplaceholder.typicode.com/posts/"
      :on-change="handleRemove"
      multiple
      :limit="3"
    >
      <el-button size="small" type="primary">點擊上傳</el-button>
    </el-upload>
  </div>
</template>

<script>
export default {
  name: "",
  data() {
    return {};
  },
  methods: {
    handleRemove(file, fileList) {
      console.log(file);
      var reader = new FileReader();
      reader.readAsDataURL(file.raw);
      reader.onload = () => {
        console.log("file 轉 base64結果:" + reader.result);
      };
      reader.onerror = function(error) {
        console.log("Error: ", error);
      };
    },
  }
};
</script>
<style scoped>
/* @import url(); 引入css類 */
</style>

在這里插入圖片描述


注意:
今天在使用Vue進行文件上傳的代碼編寫時,發現報錯:
Error in v-on handler: "TypeError: Failed to execute 'readAsDataURL' on 'FileReader': parameter 1 is not of type 'Blob'."
`在這里插入圖片描述
顯然,是傳入的file對象出了問題,根據報錯提示,我們應該傳入一個Blob對象。也就是說,file不是Blob對象
在這里插入圖片描述

我們使用console.log(file)進行調試輸出:
在這里插入圖片描述
看, raw這個屬性寫了個大大的File

把raw這個File對象傳入即可
在這里插入圖片描述
OK啦!!!
在這里插入圖片描述


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM