图片预览功能实现!!!

499 阅读1分钟

图片上传预览

图片的上传在目前的项目几乎都会用到,上传图片使如果能够及时的预览到上传图片,对于提高用户体验是相当的好,此博客就以此为基础,撰写上传图片使得预览功能.

所需效果如果所示:

22.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>
    </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
    }