中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

JavaScript中三種異步上傳文件方式
來源:易賢網 閱讀:1410 次 日期:2016-08-02 14:48:24
溫馨提示:易賢網小編為您整理了“JavaScript中三種異步上傳文件方式”,方便廣大網友查閱!

異步上傳文件是為了更好的用戶體驗,是每個前端必須掌握的技能。這里我提出三點有關異步文件上傳的方式。

使用第三方控件,如Flash,ActiveX等瀏覽器插件上傳。

使用隱藏的iframe模擬異步上傳。

使用XMLHttpRequest2來實現異步上傳。

第一種使用瀏覽器插件上傳,需要一定的底層編碼功底,在這里我就不講了,以免誤人子弟,提出這點大家可以自行百度。

第二種使用隱藏的iframe模擬異步上傳。為什么在這里說的是模擬呢?因為我們其實是將返回結果放在了一個隱藏的iframe中,所以才沒有使當前頁面跳轉,感覺就像是異步操作一樣。

先貼出代碼:

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-">

<title>隱藏的iframe上傳文件</title>

<script type="text/javascript" src="jquery路徑..."></script>

</head>

<body>

<iframe name="frm" style="display:none"></iframe>

<form action="/upload" enctype="multipart/form-data" method="post" target="frm" onsubmit="loading(true);">

<p id="upfile">附件: <input type="file" name="myfile" style="display: inline"></p>

<p id="upbtn"><input style="padding-left:px;padding-right: px;" type="submit" value="異步上傳">

<span id="uptxt" style="display: none">正在上傳...</span></p>

</form>

<div id="flist" style="border:px dotted darkgray;"></div>

<script>

// 上傳完成后的回調

function uploadFinished(fileName) {

addToFlist(fileName);

loading(false);

}

function addToFlist(fname) {

var temp = ["<p id='" + fname + "'>",

fname,

"<button onclick='delFile(\"" + fname + "\");'>刪除</button>",

"</p>"

];

$("#flist").append(temp.join(""));

}

function loading(showloading) {

if (showloading) {

$("#uptxt").show();

} else {

$("#uptxt").hide();

}

}

</script>

</body>

</html>

這種技術有兩個關鍵的地方:

1.form會指定target,提交的結果定向返回到隱藏的ifram中。(即form的target與iframe的name屬性一致)。

2.提交完成后,iframe中頁面與主頁面通信,通知上傳結果及服務端文件信息

如何與主頁面通信呢?

我們用nodejs在接收完了文件后返回了一個window.parent.主頁面定義的方法,執行后可以得知文件上傳完成。代碼很簡單:

router.post('/upload', multipartMiddleware, function(req, res) {

var fpath = req.files.myfile.path;

var fname = fpath.substr(fpath.lastIndexOf('\\') + );

setTimeout(function() {

var ret = ["<script>",

"window.parent.uploadFinished('" + fname + "');",

"</script>"];

res.send(ret.join(""));

}, );

});

執行后可以打開開發人員選項,你會發現隱藏iframe中返回了服務器的一些數據。

第三種使用XMLHttpRequest2來進行真正的異步上傳。

還是先貼出代碼:

<!DOCTYPE html>

<html lang="en">

<head>

<meta charset="UTF-">

<title>xhr level 異步上傳</title>

<script type="text/javascript" src="jquery路徑..."></script>

</head>

<body>

<div>

<p id="upfile">附件: <input type="file" id="myfile" style="display: inline"></p>

<p id="upbtn">

<input style="padding-left:px;padding-right: px;" type="button" value="異步上傳" onclick="upload();">

<span id="uptxt" style="display: none">正在上傳...</span>

<span id="upprog"></span>

<button id="stopbtn" style="display:none;">停止上傳</button>

</p>

</div>

<div id="flist" style="border:px dotted darkgray;"></div>

<script>

function upload() {

// .準備FormData

var fd = new FormData();

fd.append("myfile", $("#myfile")[].files[]);

// 創建xhr對象

var xhr = new XMLHttpRequest();

// 監聽狀態,實時響應

// xhr 和 xhr.upload 都有progress事件,xhr.progress是下載進度,xhr.upload.progress是上傳進度

xhr.upload.onprogress = function(event) {

if (event.lengthComputable) {

var percent = Math.round(event.loaded * / event.total);

console.log('%d%', percent);

$("#upprog").text(percent);

}

};

// 傳輸開始事件

xhr.onloadstart = function(event) {

console.log('load start');

$("#upprog").text('開始上傳');

$("#stopbtn").one('click', function() {

xhr.abort();

$(this).hide();

});

loading(true);

};

// ajax過程成功完成事件

xhr.onload = function(event) {

console.log('load success');

$("#upprog").text('上傳成功');

console.log(xhr.responseText);

var ret = JSON.parse(xhr.responseText);

addToFlist(ret.fname);

};

// ajax過程發生錯誤事件

xhr.onerror = function(event) {

console.log('error');

$("#upprog").text('發生錯誤');

};

// ajax被取消

xhr.onabort = function(event) {

console.log('abort');

$("#upprog").text('操作被取消');

};

// loadend傳輸結束,不管成功失敗都會被觸發

xhr.onloadend = function (event) {

console.log('load end');

loading(false);

};

// 發起ajax請求傳送數據

xhr.open('POST', '/upload', true);

xhr.send(fd);

}

function addToFlist(fname) {

var temp = ["<p id='" + fname + "'>",

fname,

"<button onclick='delFile(\"" + fname + "\");'>刪除</button>",

"</p>"

];

$("#flist").append(temp.join(""));

}

function delFile(fname) {

console.log('to delete file: ' + fname);

// TODO: 請實現

}

function loading(showloading) {

if (showloading) {

$("#uptxt").show();

$("#stopbtn").show();

} else {

$("#uptxt").hide();

$("#stopbtn").hide();

}

}

</script>

</body>

</html>

代碼有點多,但是通俗易懂。使用過AJAX的人都知道,XHR對象提供了一個onreadystatechange的回調方法來監聽整個請求/響應過程。在XMLHttpRequest2級規范中又多了幾個進度事件。有以下6個事件:

1.loadstart: 在接收到響應數據的第一個字節時觸發。

2.progress: 在接收響應期間持續不斷地觸發。

3.error: 在請求發生錯誤時觸發。

4.abort: 在因為調用abort()方法而終止連接時觸發。

5.load: 在接收到完整的響應數據時觸發。

6.loadend: 在通信完成或者觸發error,abort,load事件后觸發。

這次我們可以解讀代碼:當傳輸事件開始后,我們便在停止傳送按鈕上添加點擊事件,內置了abort方法可以停止傳送。若不點則會正常上傳直到傳送完畢為止。其后臺代碼類似第二種方法。

三種方法各有優劣,做個簡單的小結吧。

第三方控件交互性和可控性好,因為接近底層,其性能也是很優秀的。但是由于編寫難度大通常需要自己安裝插件,有時可能需要自己進行編寫。

隱藏的iframe方法我個人覺得是非常有思想的一個方法,iframe可以幫我們做很多事。這種方式具有廣泛的瀏覽器兼容性而且不需要安裝插件。但是它交互性差,上傳過程不可控,而且性能也是很一般的。

XHR2級的純ajax上傳,它必須要版本比較高一點的瀏覽器(ie9+)。但是它交互性特別好,可以看到上傳進度并且是可控的。

開發可按需求來采用不同方法。個人覺得這些文件上傳,特別是第二種提供的是一種思想,充分的利用了某些html標簽的特性,可能是我們開發人員需要多思考的地方。

更多信息請查看網絡編程
易賢網手機網站地址:JavaScript中三種異步上傳文件方式
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!

2026上岸·考公考編培訓報班

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
云南網警備案專用圖標
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網
云南網警報警專用圖標
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
国产欧美日韩三区| 国产日韩欧美综合一区| 欧美激情综合色| 亚洲精品久久嫩草网站秘色| 麻豆成人精品| 99re视频这里只有精品| 国产一区二区在线观看免费| 久久久精品国产免费观看同学| 经典三级久久| 欧美母乳在线| 篠田优中文在线播放第一区| 尤物精品在线| 欧美体内she精视频| 欧美一区二区播放| 亚洲精品国产精品乱码不99 | 日韩香蕉视频| 国产精品ⅴa在线观看h| 欧美一区二区三区在| 亚洲高清影视| 国产精品亚洲激情| 免费亚洲电影在线观看| 亚洲自拍偷拍福利| 亚洲日本乱码在线观看| 欧美日韩在线播放一区二区| 欧美在线视频不卡| 亚洲视频欧美视频| 亚洲高清一区二区三区| 国产酒店精品激情| 久久精品最新地址| 亚洲私人影院在线观看| 亚洲福利视频一区二区| 国产欧美二区| 国产精品国产三级国产 | 国产精品初高中精品久久| 久久精品国语| 亚洲午夜精品网| 黑人巨大精品欧美一区二区小视频 | 激情一区二区| 国产精品一二三| 欧美三级免费| 欧美日韩不卡一区| 亚洲欧美日韩区| 日韩网站免费观看| 国内视频一区| 国产精品色婷婷| 欧美午夜精品伦理| 欧美交受高潮1| 久久久福利视频| 久久精品亚洲国产奇米99| 亚洲精品视频免费观看| 在线观看91精品国产入口| 韩国福利一区| 国产一区二区观看| 国产亚洲精品aa午夜观看| 欧美午夜精品一区| 欧美亚洲成人网| 国产精品www色诱视频| 欧美国产极速在线| 欧美福利一区二区| 欧美精品免费在线观看| 欧美精品免费观看二区| 欧美日本在线看| 欧美人与禽猛交乱配视频| 欧美福利一区| 欧美人与性动交a欧美精品| 欧美日韩a区| 国产精品久久久久久久久久免费| 国产精品国产一区二区| 亚洲国产mv| 亚洲精品免费一区二区三区| 亚洲国产婷婷香蕉久久久久久99| **欧美日韩vr在线| 亚洲精品中文字幕有码专区| 日韩视频中文| 亚洲欧美日韩在线一区| 午夜精品影院| 久久天堂成人| 欧美人与性禽动交情品| 国产精品视频99| 在线播放日韩| 99riav1国产精品视频| 午夜精品福利一区二区三区av | 国产三级精品三级| 国语自产在线不卡| 亚洲日本国产| 午夜天堂精品久久久久| 老巨人导航500精品| 欧美日韩在线一区二区三区| 国产精品免费看片| 激情亚洲一区二区三区四区| 91久久久亚洲精品| 亚洲一区亚洲二区| 卡一卡二国产精品| 国产精品久久久久久久app| 影音先锋一区| 黄网站免费久久| 一区二区三区**美女毛片| 欧美在线一区二区三区| 蜜臀av性久久久久蜜臀aⅴ| 国产精品久久久久久妇女6080| 在线观看中文字幕不卡| 在线一区欧美| 欧美 日韩 国产一区二区在线视频 | 亚洲国产日韩欧美在线99| 亚洲制服少妇| 欧美激情中文不卡| 精品99一区二区三区| 亚洲午夜av电影| 国产欧美日韩另类一区| 亚洲丰满在线| 亚洲欧美一区二区三区在线| 欧美不卡一区| 一区二区在线视频播放| 亚洲免费一区二区| 欧美日本国产一区| 亚洲国产专区校园欧美| 久久亚洲欧美国产精品乐播| 国产精品国产福利国产秒拍| 9久草视频在线视频精品| 能在线观看的日韩av| 精品成人一区| 久久蜜臀精品av| 黄网动漫久久久| 久久精品国产亚洲高清剧情介绍| 国产精品久久久久免费a∨大胸| 亚洲欧洲一级| 欧美成人自拍视频| 在线观看亚洲视频啊啊啊啊| 久久亚洲免费| 狠狠色狠色综合曰曰| 久久久国产成人精品| 国产专区精品视频| 久久看片网站| 在线观看日产精品| 欧美大片免费观看| 亚洲精品偷拍| 欧美日韩大片一区二区三区| 亚洲精品视频中文字幕| 女女同性精品视频| 亚洲精品视频在线播放| 欧美精品在线播放| 一本色道久久99精品综合| 国产精品电影网站| 亚洲欧美一区二区三区久久| 国产精品腿扒开做爽爽爽挤奶网站| 亚洲尤物在线视频观看| 国产精品亚洲不卡a| 欧美在线一级va免费观看| 在线观看av不卡| 欧美高清视频一区二区| 亚洲美女电影在线| 欧美丝袜一区二区| 午夜亚洲一区| 激情国产一区二区| 欧美日韩成人在线视频| 亚洲欧美在线磁力| 激情一区二区三区| 欧美精品国产| 亚洲女同性videos| 在线日韩日本国产亚洲| 欧美人成在线视频| 欧美一区二区三区日韩| 亚洲国产成人在线视频| 欧美日韩一级大片网址| 午夜久久影院| 亚洲国产毛片完整版| 国产精品毛片va一区二区三区| 欧美亚洲在线视频| 亚洲精品美女在线| 国产区二精品视| 欧美日韩p片| 久久精彩视频| 中文欧美在线视频| 亚洲国产毛片完整版| 国产伦精品一区二区三区四区免费| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产三区二区一区久久| 久久久久久有精品国产| 一区二区不卡在线视频 午夜欧美不卡在 | 裸体丰满少妇做受久久99精品| 99精品久久| 黄色成人在线网址| 国产精品日韩欧美| 欧美破处大片在线视频| 久久久另类综合| 亚洲综合首页| 9久re热视频在线精品| 伊人春色精品| 国产午夜精品久久久久久免费视| 欧美国产日韩免费| 久久久久久久尹人综合网亚洲| 亚洲图片你懂的| 亚洲伦理在线观看| 亚洲国产第一| 黄色资源网久久资源365| 国产欧美精品一区| 国产精品美女久久久免费| 欧美午夜寂寞影院| 欧美日韩国产欧| 欧美乱妇高清无乱码|