大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章给大家分享的是有关JavaScript实现form表单的多文件上传的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。
创新互联是一家专业提供江城企业网站建设,专注与成都网站设计、成都做网站、HTML5建站、小程序制作等业务。10年已为江城众多企业、政府机构等服务。创新互联专业网站建设公司优惠进行中。
form表单的多文件上传,具体内容如下
formData对象可以使用一系列的键值对来模拟一个完整的表单,然后使用Ajax来发送这个表单
使用
注意:
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( '' + ' '); //追加文件 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 + ' 个文件'); });'+fileName+' ' + ''+(item.size / 1024).toFixed(2)+'K ' + '' + '
删除按钮事件
$('#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; //将不删除的放入数组中 $.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('UploadForm[excelFiles][]'); //将不删除的数组追加的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进行上传 $.ajax({ url: '/finalize/upload', type: 'POST', cache: false, data: formData, processData: false, contentType: false }).done(function(res) { if(res.code == 'ok'){ //进度条设置 var value = 0; var timer2 = setInterval(function () { value ++; $("#progress").css('width', value + "%"); if (value == 120) { clearInterval(timer2); $("#overlay").hide(); alert("文件上传成功!"); } }, 50); //删除对应按钮 $("#fileUpload").css("display","none"); $.each(deleteBtn,function (index, item) { $(item).css("display","none"); }); $('#files').append('') } }).fail(function(res) { alert("文件上传失败:" + res.msg); }); }else { alert("请选择需要上传的文件!"); } }); 文件下载
感谢各位的阅读!关于“JavaScript实现form表单的多文件上传的方法”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!