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

首頁 > 編程 > JavaScript > 正文

jQuery實現jQuery-form.js實現異步上傳文件

2019-11-19 16:42:18
字體:
來源:轉載
供稿:網友

做為一個前端開發,你肯定遇到過這樣的需求:異步上傳文件,還要兼容IE 8。[納尼,沒遇到過,那你們產品和UI對你也忒好了吧。

遇到這種需求,如果項目不是很趕,可以自己用iframe來做,如果項目比較趕的話,就可以使用jquery-form.js插件來實現,方便快捷。

一、舉個栗子

1.先下載 JQuery-form.js文件并引入,也可以使用CDN,因為是jquery插件,所以需要先引入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); } 

這樣異步上傳就完成了,至于后臺對上傳的文件的獲取,跟前臺直接提交表單上傳文件的方法是一樣的。

二、進一步

​ 還沒完呢,上面的例子是直接點擊的type=file的input異步上傳的,可是大家都知道默認的type=file的input框是很難看的,而且無法自定義樣式,這個時候,要想做好看,就需要UI提供一個點擊上傳文件的圖,然后把input隱藏,在點擊圖片的時候,再用js觸發input選擇文件,然后再點擊提交按鈕異步上傳。嗯,道理上是這樣的,然而是要兼容IE 8的呀親,不信你在IE8 下面跑跑看,一個 “XXX拒絕訪問”的大錯誤赤裸裸的躺在那兒。

​ 其實這個問題呢,是由于IE的安全機制造成的,對于低版本的IE瀏覽器來說,如果click事件不是直接穿透到input[type=file]元素上的,那么就會禁止提交,所以你用js觸發的input選擇文件自然就行不通了。

解決方法:使用label元素。

只需要把上面的form標簽里的內容改成下面這樣:

<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>  

嗯,就是這樣,至于那個好看的點擊上傳的圖片,就作為label元素的背景吧。

相信我,這樣真的可以了,兼容IE 8完全沒問題。

三、更進一步

可能你還需要判斷一下上傳的文件類型啥的,比如只讓上傳excel文件,那請這樣寫:

$(".file").bind("change",function(){   var fileType = $(this).val().substring($(this).val().lastIndexOf(".") + 1);  if(fileType != "xls" && fileType != "xlsx"){    alert("只能上傳excel文件");  }}); 

四、小結

嗯,也沒啥可小結的,其實form.js是一個全,面支持表單的jQuery插件,有很多表單相關的給你,本篇只是介紹了其中一種功能的用法而已,其他更多的用法,請參照https://github.com/jquery-form/form官方文檔。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 灵山县| 贵州省| 荣昌县| 富平县| 耒阳市| 庆元县| 彭水| 广宗县| 绥芬河市| 津市市| 思茅市| 大足县| 平泉县| 安乡县| 潜江市| 昌江| 冀州市| 定襄县| 大丰市| 麟游县| 廉江市| 武宣县| 子洲县| 米脂县| 北安市| 古蔺县| 晋江市| 崇义县| 于田县| 尚志市| 陇西县| 寿阳县| 陆川县| 循化| 宝丰县| 许昌县| 崇文区| 海兴县| 类乌齐县| 康定县| 舒兰市|