實(shí)例講解javascript實(shí)現(xiàn)異步圖片上傳方法
我們首先看下HTML代碼實(shí)現(xiàn)的form提交部分。其中大家在測(cè)試的時(shí)候需要把test的URL更換成自己的,也可以直接寫一個(gè)本地地址測(cè)試。
html代碼:
<form id="uploadForm" action="http://storage.test.com/file/upload" method="post" enctype="multipart/form-data"> <input type="hidden" name="key" id="key" value="VTZ18HM64#D_L3WX" /> <input type="file" name="uploadFiles" value="" id="fileImage" multiple='multiple' /> <div class="upload_submit"> <button type="button" id="fileSubmit" class="upload_btn">保存</button> </div> </form>
js代碼:
var Fileupload = {
fileInput: $("#fileImage").get(0),
dragDrop: $("#fileDragArea").get(0),
upButton: $("#fileSubmit").get(0),
url: $("#uploadForm").attr("action"),
})(),
//文件上傳
funUploadFile: function() {
var self = this;
for (var i = 0, file; file = this.fileFilter[i]; i++) {
(function(file) {
var xhr = new XMLHttpRequest();
if (xhr.upload) {
// 上傳中
xhr.upload.addEventListener("progress", function(e) {
self.onProgress(file, e.loaded, e.total);
}, false);
// 文件上傳成功或是失敗
xhr.onreadystatechange = function(e) {
if (xhr.readyState == 4) {
if (xhr.status == 200) {
self.onSuccess(JSON.parse(xhr.responseText));
self.funDeleteFile(file);
if (!self.fileFilter.length) {
//全部完畢
self.onComplete();
}
} else {
self.onFailure(file, xhr.responseText);
}
}
};
//準(zhǔn)備FormData對(duì)象
var myForm = document.getElementById('uploadForm');
//將文件放入FormData對(duì)象中
formData = new FormData(myForm);
// 開(kāi)始上傳
xhr.open("POST", self.url, true);
xhr.send(formData);
}
})(file);
}
},
init: function() {
var self = this;
//上傳按鈕提交
if (this.upButton) {
console.log('提示: 當(dāng)前存儲(chǔ)服務(wù)器地址', this.url)
this.upButton.addEventListener("click", function(e) {
self.funUploadFile(e);
}, false);
}
self.bindEvent();
}
};
Fileupload = $.extend(Fileupload);
Fileupload.init();
FormData 異步上傳文件
<input type="file" id="file">
一、創(chuàng)建FormData放入待上傳文件
//準(zhǔn)備FormData對(duì)象
var formData = new FormData(),
uploadFile = document.getElementById('file');
//將文件放入FormData對(duì)象中
formData.append('file', uploadFile.files[0]);
二、通過(guò)xhr發(fā)送FormData數(shù)據(jù)到服務(wù)器,實(shí)現(xiàn)文件上傳
//創(chuàng)建xhr對(duì)象
var xhr = new XMLHttpRequest();
//監(jiān)聽(tīng)文件上傳進(jìn)度
xhr.upload.onprogress = function(evt){
//lengthComputabel: 文件長(zhǎng)度是否可計(jì)算
if(evt.lengthComputable){
//evt.loaded: 已下載的字節(jié)數(shù)
//evt.total: 文件總字節(jié)數(shù)
var percent = Math.round(evt.loaded*100/evt.total);
console.log(percent);
}
}
//監(jiān)聽(tīng)文件傳輸開(kāi)始
xhr.onloadstart = function(evt){
xhr.abort() //終止上傳
}
//監(jiān)聽(tīng)ajax成功完成事件
xhr.onload = function(evt){
...
}
//監(jiān)聽(tīng)ajax錯(cuò)誤事件
xhr.onerror = function(evt){
...
}
//監(jiān)聽(tīng)ajax被中止事件
xhr.onabort = function(evt){
...
}
//監(jiān)聽(tīng)傳輸結(jié)束事件: 不管成功或者失敗都會(huì)觸發(fā)
xhr.onloaded = function(evt){
...
}
//*發(fā)起ajax請(qǐng)求數(shù)據(jù)
xhr.open('POST', '/url', true);
xhr.send(formData);
- thinkphp ajaxfileupload實(shí)現(xiàn)異步上傳圖片的示例
- php+ajax實(shí)現(xiàn)異步上傳文件或圖片功能
- JavaScript異步上傳圖片文件的實(shí)例代碼
- JS實(shí)現(xiàn)異步上傳壓縮圖片
- ajax圖片上傳,圖片異步上傳,更新實(shí)例
- java webApp異步上傳圖片實(shí)現(xiàn)代碼
- asp.net+jquery.form實(shí)現(xiàn)圖片異步上傳的方法(附j(luò)query.form.js下載)
- Android異步上傳圖片到PHP服務(wù)器
- java異步上傳圖片示例
- jquery的ajaxSubmit()異步上傳圖片并保存表單數(shù)據(jù)演示代碼
- Jquery插件之多圖片異步上傳
相關(guān)文章
防止動(dòng)態(tài)加載JavaScript引起的內(nèi)存泄漏問(wèn)題
利用Script標(biāo)簽可以跨域加載并運(yùn)行一段JavaScript腳本, 但Neil Fraser先前已指出,腳本運(yùn)行后資源并沒(méi)被釋放,即使是Script標(biāo)簽移除后。2009-10-10
基于JavaScript實(shí)現(xiàn)粒子流動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了如何通過(guò)JavaScript實(shí)現(xiàn)粒子流動(dòng)效果,文中的示例代碼講解詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下2023-09-09
javascript實(shí)現(xiàn)圖片輪播簡(jiǎn)單效果
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)圖片輪播簡(jiǎn)單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
JS獲取瀏覽器地址欄的多個(gè)參數(shù)值的任意值實(shí)例代碼
本文通過(guò)實(shí)例代碼給大家介紹了JS獲取瀏覽器地址欄的多個(gè)參數(shù)值的任意值,代碼簡(jiǎn)單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的的朋友參考下吧2018-07-07
js為鼠標(biāo)添加右擊事件防止默認(rèn)的右擊菜單彈出
本文為大家介紹下如何為使用js為鼠標(biāo)添加右擊事件防止默認(rèn)的右擊菜單彈出,感興趣的朋友可以參考下,希望對(duì)大家有所幫助2013-07-07

