图片上传预览
图片的上传在目前的项目几乎都会用到,上传图片使如果能够及时的预览到上传图片,对于提高用户体验是相当的好,此博客就以此为基础,撰写上传图片使得预览功能.
所需效果如果所示:
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>
</div>
方法一 : 使用本地图片预览FileReader
利用文件读写来将上传的文件内容获取到再渲染到页面中
1.在data中定义变量 avatar用来存储图片的路径
data () {
return {
avatar: ''
}
},
2.两个事件
2.1点击按钮触发input框选择文件文件 (李代桃僵)
2.2输入框change事件
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
}
}
},
方法二 : 上传到服务器并返回图片的URL(常用)
//输入框change事件
changeImg (e) {
// console.dir(e.target.files)
const files = e.target.files
//实现图片预览
const url = URL.creatObjectURL(files[0])
// console.log(url) // blob:http://localhost:3000/8e8a42e8-d052-4828-ac1e-40faabb49425
//直接修改img的src属性
this.$refs.refImg.src = url
}