input type=file实现图片上传,预览以及图片删除

// html

<div class="preview" v-show="previewImg" @click="previewImg=''"><img :src="previewImg" alt="" /></div>
<div class="uploadBox2">
   <div class="uploadBtn uploadImg" v-for="(item,index) in imgDatas">
       <span class="close" @click="deleteImg(index)"></span>
       <img :src="item" alt="" @click="previewImg=item">
   </div>
  <div class="uploadBtn">
      <span class="iconadd">+</span>
      <input type="file" accept="image/*" multiple @change="changeImage($event)"/>
  </div>
</div>
// css

.uploadBox2{
  display: flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
}
.uploadBtn{
  width: 60px;
  height: 60px;
  border: 1px dashed #E6E6E6;
  position: relative;
  margin: 0 8px 15px 0;
}
.uploadImg{
  border: none;
}
.uploadBtn img{
  width: 100%;
  height: 100%;
}
.uploadBtn input{
  width: 100%;
  height: 100%;
  opacity: 0;
}
.close{
  width: 15px;
  height: 15px;
  line-height: 15px;
  text-align: center;
  position: absolute;
  top: -6px;
  right: -6px;
  color: #fff;
  background: rgba(0,0,0,0.6);
  border-radius: 50%;
  font-size: 10px;
}
.iconadd{
  font-size: 20px;
  color: #E6E6E6;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  z-index: 0;
}
.preview{
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  z-index: 99;
  background: rgba(0,0,0,0.9);
}
.preview img{
  width: 100%;
  height: 100%;
  object-fit: contain;
  vertical-align: middle;
}
// JS

data(){
  return(){
      filesArr: [],
      imgDatas: [],
      previewImg: '', // 放大预览图片
  }  
},
methods: {
     // 上传图片
    changeImage(e){
      let files = e.target.files;
       // 如果没有选中文件,直接返回
      if (files.length === 0) {
        return;
      }
      let reader;
      let file;
      let imgDatas = this.imgDatas;
      for (let i = 0; i < files.length; i++) {
        file = files[i];
        this.filesArr.push(file);
        reader = new FileReader();
        if (/\.(jpe?g|png|gif)$/i.test(file.name)) {
          reader.onload = function(e) {
            if (imgDatas.indexOf(this.result) === -1) { // 判断数组里值相同的无法上传,具体看自己需求
              imgDatas.push(this.result);
            }
          };
          reader.readAsDataURL(file);
        }
      }
      e.target.value = ''// 清空value值防止 同一张图片无法重复提交
    },
    // 删除图片
    deleteImg(index){
      this.filesArr.splice(index,1);
      this.imgDatas.splice(index,1);
      console.log(this.filesArr);
      console.log(this.imgDatas);
    },    
}

最后实现的效果:

(预览放大图片:)

posted @ 2020-07-28 15:04  rachelch  阅读(894)  评论(0编辑  收藏  举报