国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript實(shí)現(xiàn)form表單的多文件上傳

2019-11-19 16:37:27
字體:
供稿:網(wǎng)友

form表單的多文件上傳,具體內(nèi)容如下

formData對象可以使用一系列的鍵值對來模擬一個完整的表單,然后使用Ajax來發(fā)送這個表單

使用<form>表單初始化FormData對象的方式上傳文件

<!--文件上傳--> <form id="uploadForm" enctype="multipart/form-data"> <div class="row" style="margin-top: 20px;">  <div class="form-group col-md-12" id="file">      <input type="hidden" name="_csrf-application"     value="<?= $csrf ?>">   <div 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;">    <div class="help-block"></div>    <div id="fileName"></div>   </div>  </div> </div> <table role="presentation" class="table"><tbody id="files"></tbody></table> </form>

注意:

1. 使用formData對象進(jìn)行表單上傳必須要為form添加enctype="multipart/form-data"屬性
2. 使用formData對象進(jìn)行表單上傳必須要對其開始填入的值按照name屬性放入該對象中,不能開始使用action上傳,后面使用formData進(jìn)行上傳,這樣會導(dǎo)致上傳數(shù)據(jù)出現(xiàn)錯誤

獲取change事件改變的文件

 var fileList; var allFile = []; //FormData對象初始化 var form = document.getElementById("upload-form"); var formData = new FormData(form); $("#uploadform-excelfiles").on('change', function (e) {  //獲取表單數(shù)據(jù)并傳入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);    $('#files').append( '<tr style="padding-top: 7px;">' +         '<td>'+fileName+'</td>' +         '<td>'+(item.size / 1024).toFixed(2)+'K</td>' +         '<td><input type="button" class="btn btn-danger delete" value="刪除"></td>' +         '</tr>');    //追加文件    formData.append('UploadForm[excelFiles][]',item);   } else {    fileError++;   }  });  if (fileError > 0) {   alert("只能上傳 “.xlsx” 格式的文件!");   document.getElementById("upload-form").reset();   return;  }  var fileCount = $('#files').find('tr').length;  $('#fileName').html('共上傳 ' + fileCount + ' 個文件'); });

刪除按鈕事件

$('#files').on('click','.delete',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;  //將不刪除的放入數(shù)組中  $.each(allFile,function (index, item) {   if(item.name == deleteName){     deleteIndex = index;   }else {    saveFile.push(item);   }  });  allFile.splice(deleteIndex,1);  //表單數(shù)據(jù)重置  formData.set("norm",norm);  formData.set("major",major);  formData.set("type",type);  formData.delete('UploadForm[excelFiles][]');  //將不刪除的數(shù)組追加的formData中  $.each(saveFile,function (index, item) {   formData.append('UploadForm[excelFiles][]',item);  });  e.target.parentNode.parentNode.remove();  var fileCount = $('#files').find('tr').length;  $('#fileName').html('共上傳 ' + fileCount + ' 個文件'); });

文件上傳事件

$("#fileUpload").on('click',function () {  var len = formData.getAll('UploadForm[excelFiles][]').length;  $("#overlay").show();  if(len > 1){    var deleteBtn = $(".delete");    //通過ajax進(jìn)行上傳    $.ajax({     url: '/finalize/upload',     type: 'POST',     cache: false,     data: formData,     processData: false,     contentType: false    }).done(function(res) {     if(res.code == 'ok'){      //進(jìn)度條設(shè)置      var value = 0;      var timer2 = setInterval(function () {       value ++;       $("#progress").css('width', value + "%");       if (value == 120) {        clearInterval(timer2);        $("#overlay").hide();        alert("文件上傳成功!");       }      }, 50);     //刪除對應(yīng)按鈕     $("#fileUpload").css("display","none");     $.each(deleteBtn,function (index, item) {      $(item).css("display","none");     });     $('#files').append('<tr><td><td><td><a type="button" class="btn btn-success pull-right" id="fileDown" href="/finalize/get-file?id=' + res.data.id + '" rel="external nofollow" >文件下載</a></td></tr>')    }   }).fail(function(res) {    alert("文件上傳失敗:" + res.msg);   });  }else {   alert("請選擇需要上傳的文件!");  } });

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 行唐县| 虹口区| 周口市| 乌拉特前旗| 通海县| 新乡县| 正镶白旗| 临泽县| 钟祥市| 曲麻莱县| 阿城市| 济阳县| 高州市| 凯里市| 定边县| 永宁县| 荣成市| 邢台市| 沿河| 巴林右旗| 秦安县| 通辽市| 阳江市| 辛集市| 进贤县| 蕉岭县| 南开区| 东港市| 池州市| 民权县| 新乡市| 宁城县| 墨江| 修文县| 左权县| 盈江县| 石楼县| 涿州市| 土默特左旗| 顺昌县| 宜川县|