首頁 > web前端 > js教程 > 主體

js實作form表單多檔案上傳的實例程式碼

零下一度
發布: 2017-05-12 09:46:52
原創
1844 人瀏覽過

這篇文章主要為大家詳細介紹了JavaScript實現form表單的多文件上傳,具有一定的參考價值,有興趣的小夥伴們可以參考一下

form表單的多重檔案上傳,具體內容如下

formData物件可以使用一系列的鍵值對來模擬一個完整的表單,然後使用Ajax來傳送這個表單

使用

表單初始化FormData物件的方式上傳檔案

<!--文件上传-->
 <form id="uploadForm" enctype="multipart/form-data">
 <p class="row" style="margin-top: 20px;">
  <p class="form-group col-md-12" id="file">   
   <input type="hidden" name="_csrf-application"
     value="<?= $csrf ?>">
   <p class="form-group field-uploadform-excelfiles" style="margin-left: 30px;">
    <label class="control-label btn btn-primary"
      for="uploadform-excelfiles">选择文件</label>
    <input type="file" id="uploadform-excelfiles" name="UploadForm[excelFiles][]"
      multiple class="attachment-upload" accept=".xlsx">
    <input type="button" id="fileUpload" value="上传文件" class="btn btn-success" style="margin-left: 15px;">
    <p class="help-block"></p>
    <p id="fileName"></p>
   </p>

  </p>
 </p>
 <table role="presentation" class="table"><tbody id="files"></tbody></table> 
</form>
登入後複製

注意:

#1. 使用formData物件進行表單上傳必須為form新增enctype="multipart/form-data"屬性
2. 使用formData物件進行表單上傳必須要對其開始填入的值依照name屬性放入該物件中,不能開始使用action上傳,後面使用formData進行上傳,這樣會導致上傳資料出現錯誤

取得change事件改變的檔案

 var fileList;
 var allFile = [];
 //FormData对象初始化
 var form = document.getElementById("upload-form");
 var formData = new FormData(form);
 $("#uploadform-excelfiles").on(&#39;change&#39;, function (e) {
  //获取表单数据并传入formData中
  var norm = $("#norm").val();
  var major = $("#major").val();
  var type = $("#type").val();
  formData.set("norm",norm);
  formData.set("major",major);
  formData.set("type",type);

  var fileError = 0;
  fileList = e.currentTarget.files;
  $.each(fileList, function (index, item) {
   var fileName = item.name;
   var fileEnd = fileName.substring(fileName.indexOf("."));
   //上传文件格式判断
   if (fileEnd == ".xlsx") {
    allFile.push(item);
    $(&#39;#files&#39;).append( &#39;<tr style="padding-top: 7px;">&#39; +
         &#39;<td>&#39;+fileName+&#39;</td>&#39; +
         &#39;<td>&#39;+(item.size / 1024).toFixed(2)+&#39;K</td>&#39; +
         &#39;<td><input type="button" class="btn btn-danger delete" value="删除"></td>&#39; +
         &#39;</tr>&#39;);
    //追加文件
    formData.append(&#39;UploadForm[excelFiles][]&#39;,item);
   } else {
    fileError++;
   }
  });
  if (fileError > 0) {
   alert("只能上传 “.xlsx” 格式的文件!");
   document.getElementById("upload-form").reset();
   return;
  }

  var fileCount = $(&#39;#files&#39;).find(&#39;tr&#39;).length;
  $(&#39;#fileName&#39;).html(&#39;共上传 &#39; + fileCount + &#39; 个文件&#39;);

 });
登入後複製

刪除按鈕事件

#
$(&#39;#files&#39;).on(&#39;click&#39;,&#39;.delete&#39;,function (e) {
  var saveFile = [];
  var norm = $("#norm").val();
  var major = $("#major").val();
  var type = $("#type").val();
  var deleteName = e.target.parentNode.previousElementSibling.previousElementSibling.textContent;
  var deleteIndex;
  //将不删除的放入数组中
  $.each(allFile,function (index, item) {
   if(item.name == deleteName){
     deleteIndex = index;
   }else {
    saveFile.push(item);
   }
  });
  allFile.splice(deleteIndex,1);
  //表单数据重置
  formData.set("norm",norm);
  formData.set("major",major);
  formData.set("type",type);
  formData.delete(&#39;UploadForm[excelFiles][]&#39;);
  //将不删除的数组追加的formData中
  $.each(saveFile,function (index, item) {
   formData.append(&#39;UploadForm[excelFiles][]&#39;,item);
  });

  e.target.parentNode.parentNode.remove();
  var fileCount = $(&#39;#files&#39;).find(&#39;tr&#39;).length;
  $(&#39;#fileName&#39;).html(&#39;共上传 &#39; + fileCount + &#39; 个文件&#39;);

 });
登入後複製

檔案上傳事件

#######################。 ###
$("#fileUpload").on(&#39;click&#39;,function () {
  var len = formData.getAll(&#39;UploadForm[excelFiles][]&#39;).length;
  $("#overlay").show();
  if(len > 1){
    var deleteBtn = $(".delete");
    //通过ajax进行上传
    $.ajax({
     url: &#39;/finalize/upload&#39;,
     type: &#39;POST&#39;,
     cache: false,
     data: formData,
     processData: false,
     contentType: false
    }).done(function(res) {
     if(res.code == &#39;ok&#39;){
      //进度条设置
      var value = 0;
      var timer2 = setInterval(function () {
       value ++;
       $("#progress").css(&#39;width&#39;, value + "%");
       if (value == 120) {
        clearInterval(timer2);
        $("#overlay").hide();
        alert("文件上传成功!");
       }
      }, 50);
     //删除对应按钮
     $("#fileUpload").css("display","none");
     $.each(deleteBtn,function (index, item) {
      $(item).css("display","none");
     });
     $(&#39;#files&#39;).append(&#39;<tr><td><td><td><a type="button" class="btn btn-success pull-right" id="fileDown" href="/finalize/get-file?id=&#39; + res.data.id + &#39;" rel="external nofollow" >文件下载</a></td></tr>&#39;)
    }

   }).fail(function(res) {
    alert("文件上传失败:" + res.msg);
   });
  }else {
   alert("请选择需要上传的文件!");
  }

 });
登入後複製
###【相關推薦】######1. ###免費js線上影片教學#########2.### JavaScript中文參考手冊###### ####3. ###php.cn獨孤九賤(3)-JavaScript影片教學#######

以上是js實作form表單多檔案上傳的實例程式碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!