中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jQuery實現input[type=file]多圖預覽上傳刪除等功能

發布時間:2020-10-15 09:20:36 來源:腳本之家 閱讀:211 作者:lander_xiong 欄目:web開發

下面我們了解一下,多圖上傳時,怎么實現預覽、上傳、刪除等功能。下圖是功能實現的預覽效果,雖然樣式有點丑,不過功能還是實現了。話不多說,直接看代碼會更直觀一些。

jQuery實現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('小明刪照片');

總結

以上所述是小編給大家介紹的jQuery實現input[type=file]多圖預覽上傳刪除等功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

海兴县| 广元市| 同江市| 克拉玛依市| 佛学| 义乌市| 虞城县| 改则县| 临洮县| 张家界市| 徐汇区| 忻州市| 阿巴嘎旗| 宜兰县| 改则县| 安福县| 周口市| 江都市| 大名县| 华容县| 葵青区| 丰镇市| 年辖:市辖区| 镇原县| 依安县| 四会市| 阜新市| 长泰县| 内黄县| 横山县| 琼中| 商洛市| 明星| 龙南县| 宜春市| 淮阳县| 上杭县| 永丰县| 哈巴河县| 陆良县| 樟树市|