使用element中的el-upload获取本地文件并转为base64码实现预览

本文介绍了如何在Vue项目中利用Element UI的el-upload组件,结合JavaScript处理文件,将本地文件转换为Base64编码,以实现实时预览功能。详细讲解了页面结构、JS代码实现以及必要的CSS样式配置。

页面结构,其中有其他属性需要设置可前往element查看

<el-upload
     class="avatar-uploader"
      ref="upload"
      action="#"
      :show-file-list="false"
      :before-upload="beforeUpload"
      :on-success="handleChange"
      :on-change="onChange"
      :auto-upload="false"
      :data="addList">
  <img v-if="imageUrl" :src="imageUrl" class="avatar" alt>
  <i v-else class="el-icon-plus avatar-uploader-icon"></i>
</el-upload>

js代码,未定义的数据自行在data中定义

beforeUpload(){
  const isJPG = file.type === 'image/jpeg';
  const isLt2M = file.size / 1024 / 1024 < 2;
  if (!isJPG) {
  this.$message.error('上传头像图片只能是 JPG 格式!');
  }
  if (!isLt2M) {
  this.$message.error('上传头像图片大小不能超过 2MB!');
  }
  return isJPG && isLt2M;
},
onChange(file,fileList){
  var _this = this;
      var event = event || window.event;
      var file = event.target.files[0];
      var reader = new FileReader(); 
      //转base64
      reader.onload = function(e) {
      _this.imageUrl = e.target.result //将图片路径赋值给src
      }
      reader.readAsDataURL(file);
},
handleChange(res, file) {
  this.imageUrl = URL.createObjectURL(file.raw);
},

css样式,摘自官方文档

<style>
  .avatar-uploader .el-upload {
    border: 1px dashed #d9d9d9;
    border-radius: 6px;
    cursor: pointer;
    position: relative;
    overflow: hidden;
  }
  .avatar-uploader .el-upload:hover {
    border-color: #409EFF;
  }
  .avatar-uploader-icon {
    font-size: 28px;
    color: #8c939d;
    width: 178px;
    height: 178px;
    line-height: 178px;
    text-align: center;
  }
  .avatar {
    width: 178px;
    height: 178px;
    display: block;
  }
</style>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值