亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-06-21 11:38:58 來源:億速云 閱讀:195 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關jQuery中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文件");
  }
});

關于“jQuery中jQuery-form.js如何實現異步上傳文件”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

盖州市| 砀山县| 洞口县| 西藏| 大连市| 安丘市| 梁河县| 尉氏县| 镇平县| 抚顺市| 安乡县| 阿拉尔市| 乐昌市| 辽宁省| 秭归县| 措美县| 吴桥县| 凤阳县| 富顺县| 德昌县| 吴忠市| 横山县| 克拉玛依市| 页游| 镶黄旗| 新化县| 鄢陵县| 宜春市| 黑龙江省| 抚顺市| 清涧县| 辽阳市| 富蕴县| 营山县| 宝清县| 易门县| 鄯善县| 成武县| 武邑县| 禹城市| 韩城市|