使用FormData實現(xiàn)上傳多個文件
更新時間:2018年12月04日 15:06:07 作者:半笙彷徨
這篇文章主要為大家詳細介紹了使用FormData實現(xiàn)上傳多個文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了FormData上傳多個文件的具體代碼,供大家參考,具體內容如下
由于項目中使用到,特此寫個Demo
html代碼:
<html> <head> <title>Title</title> <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script> </head> <body> <form enctype="multipart/form-data" id="form_example"> <input type="file" id="files" multiple/><br/><br/> <input type="submit" value="提交"/> </form> <div id='file-list-display'></div> </body> </html>
js代碼:
<script type="text/javascript"> $(document).ready(function () { var fileList = []; var fileCatcher = document.getElementById('form_example'); var files = document.getElementById("files"), renderFileList; var fileListDisplay = document.getElementById('file-list-display'), sendFile; fileCatcher.addEventListener("submit", function (event) { event.preventDefault(); //上傳文件 sendFile(); }); files.addEventListener("change", function (event) { for (var i = 0; i < files.files.length; i++) { fileList.push(files.files[i]); } renderFileList(); }); renderFileList = function () { fileListDisplay.innerHTML = ''; fileList.forEach(function (file, index) { var fileDisplayEl = document.createElement("p"); fileDisplayEl.innerHTML = (index + 1) + ":" + file.name; fileListDisplay.appendChild(fileDisplayEl); }) }; sendFile = function () { var formData = new FormData(); var request = new XMLHttpRequest(); //循環(huán)添加到formData中 fileList.forEach(function (file) { formData.append('files', file, file.name); }) request.open("POST", "/test/upload.do"); request.send(formData); } }) </script>
后端使用Spring MVC接收前端文件
配置multipart解析器:
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" p:defaultEncoding="utf-8"/>
Controller:
@RequestMapping("/upload.do") @ResponseBody public Object upload(@RequestParam MultipartFile[] files) { System.out.println(files.length); return "ok"; }
前端頁面:
請求:
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- JS中使用FormData上傳文件、圖片的方法
- jQuery用FormData實現(xiàn)文件上傳的方法
- jQuery Ajax使用FormData對象上傳文件的方法
- 談談基于iframe、FormData、FileReader三種無刷新上傳文件的方法
- JS FormData上傳文件的設置方法
- jQuery+formdata實現(xiàn)上傳進度特效遇到的問題
- 通過Ajax使用FormData對象無刷新上傳文件方法
- vuejs使用FormData實現(xiàn)ajax上傳圖片文件
- FormData+Ajax實現(xiàn)上傳進度監(jiān)控
- jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取