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

JavaScript中三種異步上傳文件方式
來源:易賢網 閱讀:1462 次 日期: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中三種異步上傳文件方式
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美精品一区二区三区高清aⅴ | 国产精品久久久久影视| 91精品国产黑色紧身裤美女| 日本福利一区二区| 欧美午夜精品一区二区三区| 色婷婷激情久久| 欧美在线视频全部完| 日本高清不卡一区| 欧美高清一级片在线| 欧美一区二区精品在线| 精品国产一区二区三区不卡| 26uuu国产电影一区二区| 国产视频在线观看一区二区三区| 国产欧美日韩不卡| 综合激情网...| 五月婷婷欧美视频| 激情六月婷婷久久| 成人不卡免费av| 欧美色涩在线第一页| 欧美大片日本大片免费观看| 久久香蕉国产线看观看99| 国产精品每日更新| 天天综合天天综合色| 国内精品伊人久久久久av一坑| 不卡一卡二卡三乱码免费网站| 欧美日韩中文字幕一区二区| 日韩欧美电影在线| 亚洲欧美另类在线| 美女网站在线免费欧美精品| 成人国产精品免费观看| 欧美日韩免费高清一区色橹橹 | 99久久精品国产导航| 在线看国产一区二区| 日韩欧美电影一二三| 亚洲欧美日韩国产中文在线| 蜜桃视频免费观看一区| 波多野结衣精品在线| 正在播放亚洲一区| 国产精品国产三级国产有无不卡| 亚洲123区在线观看| 成人h动漫精品| 日韩欧美国产不卡| 亚洲二区视频在线| caoporm超碰国产精品| 欧美一级国产精品| 亚洲综合免费观看高清完整版 | 久久综合九色综合欧美亚洲| 亚洲免费看黄网站| 东方aⅴ免费观看久久av| 欧美一区二区福利在线| 亚洲精品国产一区二区精华液 | 亚洲免费观看高清| 福利一区福利二区| 欧美电影精品一区二区| 亚洲在线中文字幕| 色综合色综合色综合| 久久久久久久久久久久电影 | 精品国产免费视频| 日韩一区二区三区视频| 亚洲人成亚洲人成在线观看图片| 激情欧美一区二区三区在线观看| 制服丝袜亚洲播放| 亚洲第一搞黄网站| 欧美亚洲国产bt| 一区二区三区日韩欧美精品| 成人午夜精品在线| 国产日韩成人精品| 国产成人综合亚洲网站| 26uuu色噜噜精品一区| 美国三级日本三级久久99| 欧美视频一区二区三区四区| 一区二区三国产精华液| 一本一本大道香蕉久在线精品| 亚洲视频免费在线观看| 国产传媒欧美日韩成人| 日本精品一区二区三区高清 | 欧美亚洲国产怡红院影院| 国产精品免费av| 成人影视亚洲图片在线| 国产婷婷色一区二区三区| 国产精品自拍av| 欧美国产欧美综合| 成人小视频在线| 亚洲欧美国产77777| 色老汉av一区二区三区| 夜夜嗨av一区二区三区中文字幕| 91福利国产成人精品照片| 亚洲国产美女搞黄色| 91精品婷婷国产综合久久| 青青草国产成人av片免费| 91精品国产91久久久久久一区二区 | 日韩欧美国产午夜精品| 国产精品自产自拍| 亚洲视频每日更新| 精品视频全国免费看| 免费成人结看片| 欧美激情一区不卡| 欧美日韩五月天| 国产真实乱子伦精品视频| 国产精品不卡一区二区三区| 在线看国产一区二区| 精品一区免费av| 亚洲少妇30p| 欧美日韩你懂的| 国产成人精品1024| 香蕉乱码成人久久天堂爱免费| 欧美一区二区三区啪啪| 不卡影院免费观看| 日本午夜精品一区二区三区电影| 国产午夜精品美女毛片视频| 欧美专区日韩专区| 国产一区视频导航| 亚洲精品视频一区二区| 久久天天做天天爱综合色| 国产视频在线观看一区二区三区| 蜜臀久久99精品久久久久久9| 国产欧美日韩在线视频| 欧美性色aⅴ视频一区日韩精品| 麻豆精品蜜桃视频网站| 一区二区三区在线影院| 亚洲精品一区二区三区蜜桃下载| 91美女在线看| 激情五月播播久久久精品| 亚洲愉拍自拍另类高清精品| 久久久久久久久久看片| 91精品国产综合久久蜜臀| 91色婷婷久久久久合中文| 国产一区二区日韩精品| 日韩专区在线视频| 亚洲视频一二区| 亚洲国产高清aⅴ视频| 日韩一卡二卡三卡国产欧美| 制服视频三区第一页精品| 色悠悠久久综合| 亚洲福中文字幕伊人影院| 亚洲国产你懂的| 国产精品色一区二区三区| 日韩一区国产二区欧美三区| 91久久精品日日躁夜夜躁欧美| 国产成人午夜电影网| 精久久久久久久久久久| 老汉av免费一区二区三区| 亚洲成精国产精品女| 亚洲欧洲无码一区二区三区| 国产午夜亚洲精品不卡| 精品处破学生在线二十三| 在线成人午夜影院| 欧美日韩一区二区在线观看| 在线免费精品视频| 欧美在线免费观看视频| 91福利精品第一导航| 在线中文字幕不卡| 99re热这里只有精品免费视频 | 国产成人精品一区二区三区四区| 日本欧美在线观看| 午夜视频一区在线观看| 国产美女在线观看一区| 日本午夜一区二区| 日本视频一区二区三区| 精品一区二区三区在线观看| 久久国产精品露脸对白| 韩日av一区二区| 国产乱码精品一区二区三区忘忧草| 日韩激情中文字幕| 麻豆精品视频在线| 国产剧情在线观看一区二区| 国产成人精品影院| 色综合久久久久| 69精品人人人人| 欧美不卡在线视频| 久久婷婷久久一区二区三区| 亚洲欧洲美洲综合色网| 亚洲国产中文字幕| 久久99国内精品| av电影天堂一区二区在线观看| 在线观看亚洲a| 日韩欧美一区二区久久婷婷| 欧美国产精品劲爆| 亚洲综合视频网| 国内精品自线一区二区三区视频| proumb性欧美在线观看| 欧美男生操女生| 亚洲国产岛国毛片在线| 天堂成人免费av电影一区| 高清不卡一区二区| 欧美日韩国产影片| 国产拍揄自揄精品视频麻豆| 亚洲一区日韩精品中文字幕| 国产一本一道久久香蕉| 欧美亚一区二区| 欧美激情一二三区| 日本不卡一区二区三区| 成人三级伦理片| 欧美一级免费观看| 亚洲黄色尤物视频| 国产精品88av| 日韩欧美一区二区三区在线| 一区二区三区不卡视频 | 成人av网在线| 日韩精品一区二区三区老鸭窝|