jQuery實(shí)現(xiàn)jQuery-form.js實(shí)現(xiàn)異步上傳文件
做為一個(gè)前端開發(fā),你肯定遇到過這樣的需求:異步上傳文件,還要兼容IE 8。[納尼,沒遇到過,那你們產(chǎn)品和UI對你也忒好了吧。
遇到這種需求,如果項(xiàng)目不是很趕,可以自己用iframe來做,如果項(xiàng)目比較趕的話,就可以使用jquery-form.js插件來實(shí)現(xiàn),方便快捷。
一、舉個(gè)栗子
1.先下載 JQuery-form.js文件并引入,也可以使用CDN,因?yàn)槭莏query插件,所以需要先引入jquery。
2.html 部分:
<form action='' enctype="multipart/form-data" method="post" name="fileForm"> <input type="file" class="file" name="filename"> </form> <button class="btn btn-primary" onclick="subimtBtn();">提交</button>
3.js部分:
function subimtBtn() {
var form = $("form[name=fileForm]");
var options = {
url:'/upload', //上傳文件的路徑
type:'post',
success:function(data){
console.log(data);
//.... //異步上傳成功之后的操作
}
};
form.ajaxSubmit(options);
}
這樣異步上傳就完成了,至于后臺(tái)對上傳的文件的獲取,跟前臺(tái)直接提交表單上傳文件的方法是一樣的。
二、進(jìn)一步
? 還沒完呢,上面的例子是直接點(diǎn)擊的type=file的input異步上傳的,可是大家都知道默認(rèn)的type=file的input框是很難看的,而且無法自定義樣式,這個(gè)時(shí)候,要想做好看,就需要UI提供一個(gè)點(diǎn)擊上傳文件的圖,然后把input隱藏,在點(diǎn)擊圖片的時(shí)候,再用js觸發(fā)input選擇文件,然后再點(diǎn)擊提交按鈕異步上傳。嗯,道理上是這樣的,然而是要兼容IE 8的呀親,不信你在IE8 下面跑跑看,一個(gè) “XXX拒絕訪問”的大錯(cuò)誤躺在那兒。
? 其實(shí)這個(gè)問題呢,是由于IE的安全機(jī)制,對于低版本的IE瀏覽器來說,如果click事件不是直接穿透到input[type=file]元素上的,那么就會(huì)禁止提交,所以你用js觸發(fā)的input選擇文件自然就行不通了。
解決方法:使用label元素。
只需要把上面的form標(biāo)簽里的內(nèi)容改成下面這樣:
<label for="upload"> <img src="upload.png"> </label> <input type="file" id="upload" class="file" name="filename" style='display:none'>
啊,不對,上面的寫法依然不能兼容IE 8,再改改:
<label for="upload"> <input type="file" id="upload" class="file" name="filename" style='opacity:0;filter:alpha(opacity=0);'> </label>
嗯,就是這樣,至于那個(gè)好看的點(diǎn)擊上傳的圖片,就作為label元素的背景吧。
相信我,這樣真的可以了,兼容IE 8完全沒問題。
三、更進(jìn)一步
可能你還需要判斷一下上傳的文件類型啥的,比如只讓上傳excel文件,那請這樣寫:
$(".file").bind("change",function(){
var fileType = $(this).val().substring($(this).val().lastIndexOf(".") + 1);
if(fileType != "xls" && fileType != "xlsx"){
alert("只能上傳excel文件");
}
}); 四、小結(jié)
嗯,也沒啥可小結(jié)的,其實(shí)form.js是一個(gè)全,面支持表單的jQuery插件,有很多表單相關(guān)的給你,本篇只是介紹了其中一種功能的用法而已,其他更多的用法,請參照https://github.com/jquery-form/form官方文檔。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jQuery動(dòng)態(tài)添加刪除select項(xiàng)(實(shí)現(xiàn)代碼)
以下是對jQuery動(dòng)態(tài)添加刪除select項(xiàng)的實(shí)現(xiàn)代碼進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過來參考下2013-09-09
jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法示例
這篇文章主要介紹了jQuery使用siblings獲取某元素所有同輩(兄弟姐妹)元素用法,結(jié)合簡單實(shí)例形式分析了siblings()函數(shù)獲取同輩元素的操作技巧,需要的朋友可以參考下2017-01-01
jQuery時(shí)間驗(yàn)證和轉(zhuǎn)換為標(biāo)準(zhǔn)格式的時(shí)間格式
本篇文章主要介紹了jQuery時(shí)間驗(yàn)證和轉(zhuǎn)換為標(biāo)準(zhǔn)格式的時(shí)間示例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03
Validform驗(yàn)證時(shí)可以為空否則按照指定格式驗(yàn)證
這篇文章主要介紹了Validform驗(yàn)證時(shí)可以為空否則按照指定格式驗(yàn)證的相關(guān)資料,需要的朋友可以參考下2017-10-10
jQuery插件FusionWidgets實(shí)現(xiàn)的Cylinder圖效果示例【附demo源碼】
這篇文章主要介紹了jQuery插件FusionWidgets實(shí)現(xiàn)的Cylinder圖效果,結(jié)合實(shí)例形式分析了jQuery使用FusionWidgets結(jié)合swf文件讀取xml數(shù)據(jù)并采用Cylinder圖展示的相關(guān)實(shí)現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-03-03
簡單實(shí)用jquery版三級聯(lián)動(dòng)select示例
本文主要為大家介紹下通過jquery實(shí)現(xiàn)三級聯(lián)動(dòng)select這里用到的json文件,只是事例,根據(jù)情況添加或編寫,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-07-07
JQuery Mobile實(shí)現(xiàn)導(dǎo)航欄和頁腳
導(dǎo)航欄由一組水平排列的鏈接構(gòu)成,通常位于頁眉或頁腳內(nèi)部。本文給大家介紹JQuery Mobile實(shí)現(xiàn)導(dǎo)航欄和頁腳的相關(guān)知識(shí),需要的朋友參考下吧2016-03-03
jQuery設(shè)置與獲取HTML,文本和值的簡單實(shí)例
本篇文章主要是對jQuery設(shè)置與獲取HTML,文本和值的簡單實(shí)例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
jQuery操作DOM_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了jQuery操作DOM,下面的DOM操作將圍繞上面的DOM樹進(jìn)行學(xué)習(xí)JQueryDOM操作,有興趣的可以了解一下2017-07-07

