無刷新上傳文件并返回自定義值
今天開發(fā)過程中遇到了這樣一個(gè)問題:需要將Excel上傳至服務(wù)器進(jìn)行解析,但是在文檔不合適的情況下希望可以不刷新頁面提示用戶文檔不合適。冥思苦想了半天,在網(wǎng)上找了不少資料最終試驗(yàn)成功,在此分享下處理方法:
首先先說下處理思路:在頁面上添加一個(gè)隱藏的iframe,設(shè)置form表單的target屬性設(shè)置為iframe的id,這樣form提交時(shí)會(huì)將excel文件以文件流的形式傳到后臺(tái),在后臺(tái)接收后可進(jìn)行自定義操作,之后返回的信息將顯示在iframe中而不進(jìn)行跳轉(zhuǎn),iframe之前設(shè)置為隱藏,所以頁面不會(huì)有變化,然后我們需要監(jiān)聽iframe內(nèi)容的變化,然后將內(nèi)容傳入主窗口中的JS方法進(jìn)行下一步的自定義處理。
頁面代碼如下:
<form id="input" action="importExcel.jhtml" method="post" enctype="multipart/form-data" target="hiddenIFrame"> <input id="excelFile" name="file" type="file" /> <input type="submit" class="button" value="導(dǎo)入excel"/> </form> <iframe id='hiddenIFrame' name='hiddenIFrame' style="display:none;"></iframe>
JS代碼如下(需引入jqeury):
$(function(){
$("#hiddenIFrame").load(function(){
var wnd = this.contentWindow;
var str = $(wnd.document.body).html();
callback(str);
});
})
function callback(info){
alert(info);
}
后臺(tái)代碼就不過多介紹了與傳統(tǒng)提交一樣,后臺(tái)會(huì)根據(jù)input組件的name值獲取到一個(gè)同名的文件流(例如上面頁面代碼中input組件的name是file,那么后臺(tái)接收到的是一個(gè)名字叫file的文件流),接收后即可進(jìn)行自定義操作。
相關(guān)文章
javascript實(shí)現(xiàn)簡單倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)倒計(jì)時(shí)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
利用BootStrap彈出二級(jí)對(duì)話框的簡單實(shí)現(xiàn)方法
彈出二級(jí)對(duì)話框,即在對(duì)話框的基礎(chǔ)上再彈出一個(gè)對(duì)話框.這篇文章主要介紹了利用BootStrap彈出二級(jí)對(duì)話框的簡單實(shí)現(xiàn)方法的相關(guān)資料,需要的朋友可以參考下2016-09-09
javascript動(dòng)畫效果打開/關(guān)閉層
用javascript實(shí)現(xiàn)打開層和關(guān)閉層的效果,原理不錯(cuò),學(xué)習(xí),記錄好2008-06-06
JS實(shí)現(xiàn)將Asp.Net的DateTime Json類型轉(zhuǎn)換為標(biāo)準(zhǔn)時(shí)間的方法
這篇文章主要介紹了JS實(shí)現(xiàn)將Asp.Net的DateTime Json類型轉(zhuǎn)換為標(biāo)準(zhǔn)時(shí)間的方法,涉及javascript針對(duì)時(shí)間與日期操作的相關(guān)技巧,需要的朋友可以參考下2016-08-08
JavaScript 空位補(bǔ)零實(shí)現(xiàn)代碼
JavaScript代碼實(shí)現(xiàn)空位補(bǔ)零2010-02-02

