话不多说直接上题目 :
如图所示 :
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')
}
}