zoukankan      html  css  js  c++  java
  • 使用element中的el-upload获取本地文件并转为base64码实现预览

    页面结构,其中有其他属性需要设置可前往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>
    博客园:https://www.cnblogs.com/xianquan
    Copyright ©2020 l-coil
    【转载文章务必保留出处和署名,谢谢!】
查看全文
  • 相关阅读:
    基于mpvue实现微信小程序区间选择(range-slider)
    node.js实现上传excel/读取excel/批量导入mysql
    java实现利用阿里巴巴开源的easyexcel进行对excel表格的导入和导出[附完整代码]
    [已解决]SpringDataJPA+Hibernate在执行executeUpdate()的时候报错 Executing an update/delete query
    重写bean类的toString()方法为JSON格式|idea设置toString()方法为JSON格式模板|idea设置toString()的模板
    [已解决]报异常java.io.InvalidClassException的解决方法|对象序列化实现Serializable会出现java.io.InvalidClassException的异常
    Invalid char (/) found at index (10) in sheet name异常原因|导出excel出现Invalid char (/) found at index (10)
    JDK各个版本的特性分析|JDK7|JDK8|JDK9|JDK10|JDK11|JDK12|JDK13特性分析
    springBoot导入本地jar并且要求通过maven打包到项目的jar中|Unable to open nested jar file 'BOOT-INF/lib/xxxxxx.jar'
    【教程】好多好看好酷的代码注释,喜欢就选一个;还可以将自己喜欢的图片一键生成代码注释
  • 原文地址:https://www.cnblogs.com/xianquan/p/13149789.html
  • Copyright © 2011-2022 走看看