vue中如何更换base64格式的字符串的头像上传

85 阅读1分钟

话不多说直接上题目 :

如图所示 : 111.png

html代码如下 :

<div>
      <!-- 图片,用来展示用户选择的头像 -->
      <!-- v-if / v-else 动态预览头像 -->
      <img :src="avatar" alt="" v-if="avatar"/>
      <img src="@/assets/images/avatar.jpg" alt="" v-else/>

      <!-- 按钮区域 -->
      <div class="btn-box">
        <input type="file" accept="image/*" style="display:none" ref="refImg" @change="changeImg">
        <el-button type="primary" icon="el-icon-plus" @click="chooseImg">选择图片</el-button>
        <!-- 动态禁止: 当avatar为空的时候禁用(没有图片的时候) -->
        <el-button type="success" icon="el-icon-upload" :disabled="avatar === ''" @click="uploadPic">上传头像</el-button>
      </div>

script代码如下 :

 data () {
    return {
      //定义变量存储base64格式的字符串
      avatar: ''
    }
  },
  methods: {
    // 选择图片点击事件
    chooseImg () {
      // 李代桃僵,触发输入框选择图片事件
      this.$refs.refImg.click()
    },
    // 选择图片 e.target -- input
    changeImg (e) {
    //   console.dir(e.target.files[0])
      if (e.target.files.length === 0) {
        // 没有选择图片(可省略) 未上传头像,重置avatar
        // this.avatar = ''
      } else {
        // 选择了一张图片, 接口文档要求: 图片对象 => base64图片对象
        // 1. 文件读取器(浏览器自带) new FileReader
        const reader = new FileReader()
        // console.log(reader)  //有事件 onload: 监听文件加载完成 result: 结果 ; 有原型 readAsDataURL: 读取文件为base64格式
        // 2. 读取文件对象
        reader.readAsDataURL(e.target.files[0])
        // 3.监听onload文件读取完毕事件
        reader.onload = () => {
        //   console.log(reader.result) // 结果为base64格式的url
        // 存储base64的路径
          this.avatar = reader.result
        }
      }
    },
    async uploadPic () {
      const { data: res } = await this.$http.patch('/my/update/avatar', { avatar: this.avatar })
      //   console.log(res)
      if (res.code !== 0) return
      this.$message.success(res.message)
      // 重新获取用户信息
      this.$store.dispatch('initUserInfo')
    }
  }