無(wú)刷新上傳文件并返回自定義值
今天開(kāi)發(fā)過(guò)程中遇到了這樣一個(gè)問(wèn)題:需要將Excel上傳至服務(wù)器進(jìn)行解析,但是在文檔不合適的情況下希望可以不刷新頁(yè)面提示用戶(hù)文檔不合適。冥思苦想了半天,在網(wǎng)上找了不少資料最終試驗(yàn)成功,在此分享下處理方法:
首先先說(shuō)下處理思路:在頁(yè)面上添加一個(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è)置為隱藏,所以頁(yè)面不會(huì)有變化,然后我們需要監(jiān)聽(tīng)iframe內(nèi)容的變化,然后將內(nèi)容傳入主窗口中的JS方法進(jìn)行下一步的自定義處理。
頁(yè)面代碼如下:
<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)代碼就不過(guò)多介紹了與傳統(tǒng)提交一樣,后臺(tái)會(huì)根據(jù)input組件的name值獲取到一個(gè)同名的文件流(例如上面頁(yè)面代碼中input組件的name是file,那么后臺(tái)接收到的是一個(gè)名字叫file的文件流),接收后即可進(jìn)行自定義操作。
- jQuery實(shí)現(xiàn)jQuery-form.js實(shí)現(xiàn)異步上傳文件
- 使用jQuery ajaxupload插件實(shí)現(xiàn)無(wú)刷新上傳文件
- 通過(guò)Ajax使用FormData對(duì)象無(wú)刷新上傳文件方法
- 通過(guò)隱藏iframe實(shí)現(xiàn)無(wú)刷新上傳文件操作
- 談?wù)劵趇frame、FormData、FileReader三種無(wú)刷新上傳文件的方法
- PHP無(wú)刷新上傳文件實(shí)現(xiàn)代碼
- JavaScript上傳文件時(shí)不用刷新頁(yè)面方法總結(jié)(推薦)
相關(guān)文章
DWR3 訪(fǎng)問(wèn)WEB元素的兩種方法實(shí)例詳解
這篇文章主要介紹了DWR3 訪(fǎng)問(wèn)WEB元素的兩種方法實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-01-01基于JavaScript偽隨機(jī)正態(tài)分布代碼實(shí)例
這篇文章主要介紹了基于JavaScript偽隨機(jī)正態(tài)分布代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11js 獲取json數(shù)組里面數(shù)組的長(zhǎng)度實(shí)例
下面小編就為大家?guī)?lái)一篇js 獲取json數(shù)組里面數(shù)組的長(zhǎng)度實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10Enter轉(zhuǎn)換為T(mén)ab的小例子(兼容IE,Firefox)
這篇文章介紹了Enter轉(zhuǎn)換為T(mén)ab的小例子(兼容IE,Firefox),有需要的朋友可以參考一下2013-11-11JavaScript實(shí)現(xiàn)拖拽元素對(duì)齊到網(wǎng)格(每次移動(dòng)固定距離)
最近在做一個(gè)拖拽元素的附加功能,就是對(duì)齊到網(wǎng)格,實(shí)際上就是確定好元素的初始位置,然后拖拽元素時(shí),每次移動(dòng)固定的距離。讓元素都可以在網(wǎng)格內(nèi)對(duì)齊2016-11-11