使用FormData實(shí)現(xiàn)上傳多個文件
更新時間:2018年12月04日 15:06:07 作者:半笙彷徨
這篇文章主要為大家詳細(xì)介紹了使用FormData實(shí)現(xiàn)上傳多個文件功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實(shí)例為大家分享了FormData上傳多個文件的具體代碼,供大家參考,具體內(nèi)容如下
由于項目中使用到,特此寫個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"; }
前端頁面:
請求:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- JS中使用FormData上傳文件、圖片的方法
- jQuery用FormData實(shí)現(xiàn)文件上傳的方法
- jQuery Ajax使用FormData對象上傳文件的方法
- 談?wù)劵趇frame、FormData、FileReader三種無刷新上傳文件的方法
- JS FormData上傳文件的設(shè)置方法
- jQuery+formdata實(shí)現(xiàn)上傳進(jìn)度特效遇到的問題
- 通過Ajax使用FormData對象無刷新上傳文件方法
- vuejs使用FormData實(shí)現(xiàn)ajax上傳圖片文件
- FormData+Ajax實(shí)現(xiàn)上傳進(jìn)度監(jiān)控
- jQuery Ajax使用FormData上傳文件和其他數(shù)據(jù)后端web.py獲取
相關(guān)文章
js當(dāng)前頁面登錄注冊框,固定div,底層陰影的實(shí)例代碼
下面小編就為大家?guī)硪黄猨s當(dāng)前頁面登錄注冊框,固定div,底層陰影的實(shí)例代碼。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10JavaScript 學(xué)習(xí)筆記(七)字符串的連接
javascript 字符串的連接效率問題,需要的朋友可以參考下。2009-12-12js使瀏覽器窗口最大化實(shí)現(xiàn)代碼(適用于IE)
點(diǎn)擊最大化按鈕后,瀏覽器的內(nèi)容填充滿顯示器,瀏覽器窗口的邊框被擠出顯示器。而該js的最大化效果是瀏覽器的邊框在顯示器內(nèi)顯示,具體實(shí)現(xiàn)如下,感興趣的朋友可以參考下2013-08-08