zoukankan      html  css  js  c++  java
  • 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);
        },    
    }

    最后实现的效果:

    (预览放大图片:)

  • 相关阅读:
    HDU 2553 N皇后问题
    HDU 2553 N皇后问题
    HDU 1045 Fire Net
    HDU 1045 Fire Net
    HUD 1175 连连看
    HUD 1175 连连看
    poj3190 Stall Reservations (贪心+优先队列)
    poj3190 Stall Reservations (贪心+优先队列)
    ThinkPHP 模板截取字符串 【转载】
    鼠标位置距浏览器窗体距离
  • 原文地址:https://www.cnblogs.com/rachelch/p/13391186.html
Copyright © 2011-2022 走看看