欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js動態(tài)在form上插入enctype=multipart/form-data的問題

 更新時間:2012年05月24日 20:00:25   作者:  
在做文件上傳的時候碰到了一個比較奇怪的問題,IE6,7,8上傳文件總是失敗,服務端接收不到文件的問題
我們都知道要讓form能提交文件,需要在form上指定enctype=multipart/form-data的attribute,這樣才能上傳文件,關于enctype的文章很多,就不再做解釋。

問題是因為使用了MVC的Html.BeginForm()來輸出表單代碼,默認是沒有加入enctype的,

復制代碼 代碼如下:

@using (Html.BeginForm()) {
}

在PartialView中有一個<input type="file" />用來上傳文件,又不想為了這個PartialView去修改父頁面的Html.BeginForm(),我的做法是在PartialView中用腳本來為form加入enctype:

復制代碼 代碼如下:

$(function(){
$('#file').parents('form').attr('enctype', 'multipart/form-data');
});

最近的主流瀏覽器都測試通過沒問題,唯獨IE的幾個舊版本出問題,試了手工在Html.BeginForm()中加入enctype是可以解決問題的,說明問題出在以上的腳本。多方查找終于發(fā)現(xiàn)出題出現(xiàn)在于IE6,7,8不支持直接attr('enctype', 'multipart/form-data'),而是設置dom屬性encoding='multipart/form-data',最終的腳本代碼修改為:

復制代碼 代碼如下:

$(function () {
$('#file').parents('form').attr('enctype', 'multipart/form-data').get(0).encoding = 'multipart/form-data';
});

相關文章

最新評論