上传头像upload的简易方法,转base64调接口的

1.首页使用el-image显示数据,用的是转base64后端返给的

javascript 复制代码
 <el-table-column prop="avatar" align="center" label="头像">
          <template #default="scope">
            <el-image style="height: 40px;width: 40px;" :src="scope.row.avatar"></el-image>
          </template>
        </el-table-column>

  private url = 'https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg'

2.在添加的页面上的操作

javascript 复制代码
//写好组件
 <el-upload class="upload-demo" ref="upload" action="" :on-remove="handleRemove" :file-list="file_list" :on-change="getFile"
          :auto-upload="false" list-type="picture" :limit="1">
          <el-button size="small" type="primary">上传人物头像</el-button>
        </el-upload>




//存放base64最后放接口里的
 private icon: any = ''

//存放图片的list
  private file_list: any[] = []

// 移除上传的文件时的回调
  private handleRemove() {
    this.icon = ''
    this.$delete(this.file_list, 0)
  }


 // 图片转base64  核心
  private getBase64(file) {
    return new Promise(function (resolve, reject) {
      let reader = new FileReader()
      let imgResult = ''
      reader.readAsDataURL(file)
      reader.onload = function () {
        imgResult = reader.result as any
      }
      reader.onerror = function (error) {
        reject(error)
      }
      reader.onloadend = function () {
        resolve(imgResult)
      }
    })
  }


//  当文件状态改变、添加文件、上传成功和上传失败时调用,控制大小和类型
  private getFile(file, fileList) {
    let fileType = file.name.substring(file.name.lastIndexOf('.') + 1)
    let fileSize = file.size / 1024 / 1024 < 5
    if (fileType !== 'png' && fileType !== 'jpg' && fileType !== 'jpeg') {
      ;(this.$refs.upload as any).clearFiles()
      ElMessage({
        message: '上传文件只能是 .png、.jpg、jpeg格式!',
        type: 'warning'
      })
      return false
    } else if (!fileSize) {
      ;(this.$refs.upload as any).clearFiles()
      ElMessage({
        message: '上传文件大小不能超过 5MB!',
        type: 'warning'
      })
      return false
    } else {
      // this.isImage = true
      this.getBase64(file.raw).then((res) => {
        this.icon = res
      })
    }
  }




//再打开编辑的时候需要的操作
//判断带过来的图片有没有base64数据,有就返回它,在dialog显示,没有就清空,解决空白图片问题
 if (rowData.avatar) {
        this.file_list = [{ url: rowData.avatar }]
      } else {
        this.file_list = []
      }
相关推荐
未来龙皇小蓝7 分钟前
RBAC前端架构-02:集成Vue Router、Vuex和Axios实现基本认证实现
前端·vue.js·架构
空白诗12 分钟前
高级进阶 React Native 鸿蒙跨平台开发:slider 滑块组件 - 进度条与评分系统
javascript·react native·react.js
晓得迷路了20 分钟前
栗子前端技术周刊第 116 期 - 2025 JS 状态调查结果、Babel 7.29.0、Vue Router 5...
前端·javascript·vue.js
How_doyou_do22 分钟前
执行上下文、作用域、闭包 patch
javascript
叫我一声阿雷吧28 分钟前
深入理解JavaScript作用域和闭包,解决变量访问问题
开发语言·javascript·ecmascript
淡忘_cx35 分钟前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins
顾北1235 分钟前
AI对话应用接口开发全解析:同步接口+SSE流式+智能体+前端对接
前端·人工智能
iDao技术魔方1 小时前
深入Vue 3响应式系统:为什么嵌套对象修改后界面不更新?
javascript·vue.js·ecmascript
历程里程碑1 小时前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask
摸鱼的春哥1 小时前
春哥的Agent通关秘籍07:5分钟实现文件归类助手【实战】
前端·javascript·后端