首页 > 语言 > JavaScript > 正文

JavaScript实现form表单的多文件上传

2024-05-06 15:17:21
字体:
来源:转载
供稿:网友

form表单的多文件上传,具体内容如下

formData对象可以使用一系列的键值对来模拟一个完整的表单,然后使用Ajax来发送这个表单

使用<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对象进行表单上传必须要为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('change', 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);    $('#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 + ' 个文件'); });            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选