Element-ui手动上传base64图片

本文介绍如何使用Vue.js实现图片上传功能,并将上传的图片转换为Base64编码字符串,通过自定义HTTP请求处理文件上传,利用FileReader API读取文件并转换为Base64格式。
<template>

<el-upload
  class="avatar-uploader"
  action="#"
  :show-file-list="false"
  :http-request="getFileMsg">
  <img v-if="imageUrl" :src="imageUrl" class="avatar">
  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

<button @click="submit">获取图片base64串</button>
</template>
export default{

   data() {
      return {
        imageUrl: ''
      }
    },


methods: {
      submit(){
        console.log('图片base64串'+this.imageUrl);
      },
      getFileMsg(content) {
        console.log(content);

        this.getBase64(content.file).then(res => {
         
          this.imageUrl = res;
        })
      },
      // 转换base64格式
      getBase64(file) {
        return new Promise(function (resolve, reject) {
          let reader = new FileReader();
          let imgResult = "";
          reader.readAsDataURL(file);
          reader.onload = function () {
            imgResult = reader.result;
          };
          reader.onerror = function (error) {
            reject(error);
          };
          reader.onloadend = function () {
            resolve(imgResult);
          };
        });
      },


    }

}

 

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值