Html5如何實現文件異步上傳功能
如何利用Html5的FormData實現文件的異步上傳?下面本站小編帶大家一起來看看詳細操作方法,還可以實現上傳進度條和文件大小驗證等,代碼簡單易懂,有需要的'的朋友參考一下!想了解更多相關信息請持續關注我們應屆畢業生考試網!
1 簡介
開發文件上傳功能從來不是一件愉快的事,異步上傳更是如此,使用過iframe和Flash的上傳方案,也都感覺十分的彆扭。本文簡要簡紹利用Html5的FormData實現文件的異步上傳,還可以實現上傳進度條和文件大小驗證等。服務端使用springMVC的方案進行處理。
2 Html代碼
<form id="myForm">
<input type="file" id="u_photo" name="u_photo" />
<input type="button" id="submit-btn" value="上傳" />
</form>
3 JQuery上傳
$("#submit-btn")('click', function() {
$({
url:"/test/upload",
type:"post",
data:new FormData($("#myForm")(0)),
//十分重要,不能省略
cache: false,
processData: false,
contentType: false,
success: function () {
alert("上傳成功!");
}
});
});
4 JQuery文件大小驗證
文件大小的及相應行為的控制,需根據需要自行處理,本方法只是示例方法。
$('#u_photo')('change', function() {
var file = s[0];
if ( > 1024*1000) {
alert('文件最大1M!')
}
});
5 JQuery進度條
在ajax方法中加入xhr即可控制上傳進度,進度條可以使用html5的progress也可使用其它的進度條。顯示及隱藏進度條需要自行處理,本方法只是簡單介紹了進度條的基本控制。
xhr: function() {
var myXhr = $();
if (ad) {
ventListener('progress', function(e) {
if (thComputable) {
$('progress')({
value: ed,
max: l,
});
}
} , false);
}
return myXhr;
}
6 springMVC服務端
6.1 maven依賴
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.2</version>
</dependency>
6.2
<bean id="multipartResolver" class="onsMultipartResolver" />
6.3 Controller
示例程序,並未給出文件驗證,存儲及處理的相應代碼。
@RequestMapping(value="/test/upload",method = )
@ResponseBody
public String upload(@RequestParam("u_photo") MultipartFile u_photo) {
tln("u_photo="+u_ize());
return "ok";
}
7 兼容性
IE 10+, Firefox 4.0+, Chrome 7+, Safari 5+, Opera 12+
-
SQl常用增刪改查模板
篇一:SQl常用增刪改查SQL常用增刪改查語句增加現在有一張表,表(Test)裏面有三個字段,分別為sno,sname,age。舉例用一條增加SQL語句,插入一條數據進庫。語句:Insertinto表名value(‘數據1’,’數據2’,’數據3’)具體操作:Insertintotestvalues('test','te...
-
如何理解Javascript的caller,callee,call,apply區別
在提到上述的概念之前,首先想説説javascript中函數的隱含參數:argumentsarguments該對象代表正在執行的函數和調用它的函數的參數。[function.]arguments[n]參數function:選項。當前正在執行的Function對象的名字。n:選項。要傳遞給Function對象的從0開始的參數值...
-
win2008 ASP顯示500內部錯誤不能顯示詳細錯誤的解決方法
在win2008系統中,有用户遇到這樣的情況:網站後台顯示500內部錯誤,但是卻無法打開詳細的錯誤信息。無法查看詳細的錯誤信息,用户就不能根據具體問題來解決了,這是一件很麻煩的事情。其實用户可以通過修改win2008系統中的IIS設置來顯示這個詳細的錯誤信息。一、造成50...
-
PHP開發工程師的具體職責14篇
PHP開發工程師的具體職責1職責:1、對公司新的網站項目、系統項目、小程序項目進行開發;2、維護支持公司現有的網絡和系統平台工作運行;3、按時、獨立、高質量地完成工作,確保相關代碼邏輯的正確性及健壯性;4、開發、維護、升級和優化系統,並能快速定位並及時修復...