实现input[type=file]多图预览上传删除等功能

下面我们了解一下,多图上传时,怎么实现预览、上传、删除等功能。下图是功能实现的预览效果,虽然样式有点丑,不过功能还是实现了。话不多说,直接看代码会更直观一些。

在这里插入图片描述

首先定义一下基本格式,样式代码自行脑补:

<body>
  <div class="upload-header">
    <input id="upload" type="file" accept="image/*" multiple="multiple">
    <button class="btn">点击上传</button>
  </div>
  <div class="img-box">
    <!-- 存放预览图片 -->
  </div>
</body>

接着定义看一下具体的js实现代码,我是基于JQ做的开发,方便DOM的操作。

1. 预览功能的实现

这里监听input[type=file]的change事件,在回调函数中,取到暂存区的文件e.target.files,通过遍历files 文件属性,使用FileReader 函数读取文件的值,然后使用append方法把图片放入指定盒子中。备注::FileReader是一种异步文件读取机制,结合input:file可以很方便的读取本地文件。

imgPreview: function () {
   var that = this;
   $('.upload-header').on('change', '#upload', function(e) {
     var files = e.target.files;
     if (files.length > 0) {
       for (var i = 0; i < files.length; i++) {
         var reader = new FileReader();
         reader.onload = function () {
           var text = `
             <div class="img-list">
               <img src="${this.result}" alt="">
               <div class="del-img">删除</div>
             </div>
           `
           $('.img-box').append(text);
         };
         reader.readAsDataURL(files[i]);
         that.filesList.push(files[i]);
       };
     };
   })
 }

2. 图片删除功能

这里是使用on方法对预览的图片添加点击事件,这里使用on方法主要是因为on方法对后面添加的dom可以继续监听。当需要删除照片时,直接删除其图片的父节点及以下节点就可以了。此时记得把暂存区的文件filesList也要对应删除。

 delImage: function () {
   var that = this;
    $('.img-box').on('click', '.del-img', function () {
      var delStatus = confirm('确认这张图片删除吗?');
      if (delStatus) {
        var index = $(this).parent().index();
        $(this).parent().remove();
        that.filesList.splice(index, 1);
        console.log('我删除啦', index);
      };
    });
  }

2. 图片批量上传功能

图片上传我定义了两个方法,第一方法是点击上传后,对所有文件进行遍历,依次调取上传的方法(因为用的七牛上传工具,只支持单个文件上传,所以采取了遍历的方式)。第二个方法使用了jq的ajax的post上传方式,使用FormData实例,添加file属性进行上传。因为是批量上传,所以我使用了定义临时变量flag 的方式来判断文件是否都上传完成,当flag的值与filesList的数量一致时,就可以判断所有上传完成。使用方法比较low,如果其他好的方法可以留言交流。

clickUpload: function () {
  var that = this;
  var filesList = this.filesList;
  $('.btn').on('click', function() {
    that.flag = 0;
    if (filesList.length > 0) {
      for (var i = 0; i < filesList.length; i++) {
        that.upLoadMethod(filesList[i]);
      }
    };
  }) 
},
upLoadMethod: function (file) {
  var that = this;
   var formData = new FormData();
   formData.append('file', file);
   $.ajax({
     type: "post",
     url: 'http://172.16.1.99:8703/file/upload',
     data: formData,
     mimeType: "multipart/form-data",
     dataType: "json",
     async: false,
     cache: false, //上传文件不需要缓存
     contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data"
     processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
     success: function (response) {
       that.flag += 1;
       if (that.flag === that.filesList.length) {
         console.log('我上传完成了');
       };
     },
     error: function (err) {
       console.log('上传失败');
     }
   });
 },

以下是完整的js代码,供参考:

<script>
  function UploadFunction (name) {
    this.name = name;
    this.init();
  };
  UploadFunction.prototype = {
    // 初始化
    init: function () {
      this.clickUpload();
      this.imgPreview();
      this.delImage();
    },
    flag: 0,
    filesList: [],
    // 点击上传
    clickUpload: function () {
      var that = this;
      var filesList = this.filesList;
      $('.btn').on('click', function() {
        that.flag = 0;
        if (filesList.length > 0) {
          for (var i = 0; i < filesList.length; i++) {
            that.upLoadMethod(filesList[i]);
          }
        };
      }) 
    },
    imgPreview: function () {
      var that = this;
      $('.upload-header').on('change', '#upload', function(e) {
        var files = e.target.files;
        console.log(files);
        if (files.length > 0) {
          for (var i = 0; i < files.length; i++) {
            var reader = new FileReader();
            reader.onload = function () {
              var text = `
                <div class="img-list">
                  <img src="${this.result}" alt="">
                  <div class="del-img">删除</div>
                </div>
              `
              $('.img-box').append(text);
            };
            reader.readAsDataURL(files[i]);
            that.filesList.push(files[i]);
          };
        };
      })
    },
    upLoadMethod: function (file) {
      var that = this;
      var formData = new FormData();
      formData.append('file', file);
      $.ajax({
        type: "post",
        url: '这里使用上传的地址/upload',
        data: formData,
        mimeType: "multipart/form-data",
        dataType: "json",
        async: false,
        cache: false, //上传文件不需要缓存
        contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data"
        processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
        success: function (response) {
          that.flag += 1;
          if (that.flag === that.filesList.length) {
            console.log('我上传完成了');
          };
        },
        error: function (err) {
          console.log('上传失败');
        }
      });
    },
    delImage: function () {
      var that = this;
      $('.img-box').on('click', '.del-img', function () {
        var delStatus = confirm('确认这张图片删除吗?');
        if (delStatus) {
          var index = $(this).parent().index();
          $(this).parent().remove();
          that.filesList.splice(index, 1);
          console.log('我删除啦', index);
        };
      });
    }
  }
  var UploadFunction = new UploadFunction('小明删照片');
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值