国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > HTML5 > 正文

Html5實現文件異步上傳功能

2024-09-05 07:22:00
字體:
來源:轉載
供稿:網友

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").on('click', function() {    $.ajax({        url:"/test/upload",        type:"post",        data:new FormData($("#myForm").get(0)),        //十分重要,不能省略        cache: false,        processData: false,        contentType: false,        success: function () {            alert("上傳成功!");        }    });});

4 JQuery文件大小驗證

文件大小的及相應行為的控制,需根據需要自行處理,本方法只是示例方法。

$('#u_photo').on('change', function() {    var file = this.files[0];    if (file.size > 1024*1000) {        alert('文件最大1M!')    }});

5 JQuery進度條

在ajax方法中加入xhr即可控制上傳進度,進度條可以使用html5的progress也可使用其它的進度條。顯示及隱藏進度條需要自行處理,本方法只是簡單介紹了進度條的基本控制。

xhr: function() {    var myXhr = $.ajaxSettings.xhr();    if (myXhr.upload) {        myXhr.upload.addEventListener('progress', function(e) {            if (e.lengthComputable) {                $('progress').attr({                    value: e.loaded,                    max: e.total,                });            }        } , 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 servlet-context.xml

<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver" />

6.3 Controller

示例程序,并未給出文件驗證,存儲及處理的相應代碼。

@RequestMapping(value="/test/upload",method = RequestMethod.POST)@ResponseBodypublic String upload(@RequestParam("u_photo") MultipartFile u_photo) {    System.out.println("u_photo="+u_photo.getSize());    return "ok";}

7 兼容性

IE 10+, Firefox 4.0+, Chrome 7+, Safari 5+, Opera 12+

8 推薦閱讀

如果對上述方案不滿意,推薦使用如下的解決方案:

JQuery File Uploader

以上所述是小編給大家介紹的Html5實現文件異步上傳功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鸡泽县| 遵义市| 浠水县| 寿宁县| 汉中市| 万全县| 吉林省| 尤溪县| 论坛| 翁源县| 安新县| 思南县| 商南县| 平泉县| 樟树市| 昔阳县| 原平市| 东城区| 天全县| 广州市| 龙胜| 诸暨市| 浑源县| 元阳县| 文山县| 凌海市| 泸州市| 杂多县| 桐城市| 合阳县| 故城县| 抚远县| 屏南县| 连州市| 遂昌县| 灵武市| 宁明县| 恩平市| 多伦县| 峡江县| 若尔盖县|