摘要:方案一表單上傳該方案優(yōu)點是支持好,缺點刷新頁面。提交原理就是上傳文件的重點。當使用有文件上傳控件的表單時,該值是必需的將空格轉換為符號,但不編碼特殊字符方案二表單上傳優(yōu)化方案一缺點該方案的優(yōu)點也是支持好,缺點是不支持跨域。
書寫是為了更好的記憶。
方案一:form表單上傳該方案優(yōu)點是支持好,缺點刷新頁面。
原理:enctype就是form上傳文件的重點。
值 | 描述 |
---|---|
application/x-www-form-urlencoded | 默認。在發(fā)送前對所有字符進行編碼(將空格轉換為 "+" 符號,特殊字符轉換為 ASCII HEX 值) |
multipart/form-data | 不對字符編碼。當使用有文件上傳控件的表單時,該值是必需的 |
text/plain | 將空格轉換為 "+" 符號,但不編碼特殊字符 |
該方案的優(yōu)點也是支持好,缺點是不支持跨域。
原理:通過target把響應指向一個iframe頁面,之后拿到返回數據。
值 | 描述 |
---|---|
_blank | 在新窗口/選項卡中打開 |
_self | 默認, 在同一框架中打開 |
_parent | 在父框架中打開。 |
_top | 在整個窗口中打開 |
framename | 在指定的 iframe 中打開 |
該方案的缺點兼容問題-caniuse,兼容有兩個方向一是低版本ie不支持CORS跨域,一個就是input新加的Files。優(yōu)點就是異步,進度條,判斷大小,處理,跨域。
var file = input.files[0]; var xhr = new XMLHttpRequest(); if (xhr.upload) { xhr.upload.addEventListener("progress", function(e) { console.log(file, e.loaded, e.total); }, false); // 文件上傳成功或是失敗 xhr.onreadystatechange = function(e) { if (xhr.readyState == 4) { if (xhr.status == 200) { console.log("成功", xhr.responseText) } else { console.log("失敗") } } } // 開始上傳 xhr.open("POST", "url", true); xhr.send(file); }方案四:ajax-formData上傳-多字段多文件;
該方案基本同上,只不過使用了FormData,缺點就是formData的兼容
var formData = new FormData(); formData.append("file", input.files[0]); xhr.send(formData);其他方案:
1. SWFupload Flash上傳 2. jquery.form.js 其他插件上傳需求一:拖拽上傳
使用drop事件,獲取e.dataTransfer
document.querySelector("body").addEventListener("drop", (e)=>{ e.preventDefault();//不寫的話,就打開了 console.log(e.dataTransfer.files[0]) });需求二:截圖-粘貼-上傳
使用paste事件,獲取e.clipboardData
document.querySelector("body").addEventListener("paste", (e)=>{ e.preventDefault();//不寫的話,就打開了 console.log(e.clipboardData.files[0]) });需求三:base64轉換上傳
場景發(fā)生在,一個和客戶端交互的情況下,客戶端選擇的圖片之后返給我了一個base64,讓我上傳這個,而且接口那邊還不改,就要文件。代碼寫的比較啰嗦,其實也用不了這么多東西,當時也是第一次接觸atob、Blob、ArrayBuffer這些東西,就寫成這樣了。
function(data){ var _str = atob(data.base64Str) var _filePath = ((data.filePath.match(/.(jpg|jpeg|png|bmp)$/) || [])[1] || "png").toLowerCase(); var _filePathHash = { jpg:"image/jpeg",jpeg:"image/jpeg",png: "image/png",bmp:"application/x-bmp", } var pre = "--------------------------1 Content-Disposition: form-data; name="file"; filename="1.png" Content-Type: "+_filePathHash[_filePath]+" "; var end = " --------------------------1--"; var buffer = new ArrayBuffer(_str.length); var uint8 = new Uint8Array(buffer); for(var i in _str){ uint8[i] = _str.charCodeAt(i); } var blob = new Blob([pre, uint8, end], {type: _filePathHash[_filePath]}); var oReq = new XMLHttpRequest(); oReq.open("POST", "url", true); oReq.setRequestHeader("Content-Type", "multipart/form-data; boundary=------------------------1") oReq.onreadystatechange=function(){if (oReq.readyState==4 && oReq.status==200){console.log(oReq.responseText); } oReq.send(blob);需求四
上傳一般來說都是要寫樣式的,不能說光是默認的input樣式就ok,但是呢,樣式又不是那么太好寫,我們怎么辦呢?
方案一label標簽的for去觸發(fā)input的單擊,這樣不就好了嗎?input的樣式不好寫,那我們把他藏起來,給label寫樣式。
方案二input[type=file]左邊是一個input右邊是個按鈕,其實是按鈕的樣式不好改,那么我們外面包裹一層overlfow:hidden,然后給input設置成一個極大,讓他所有不一樣的東西,都超出去,這樣就是在能改動的區(qū)域改動了
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://systransis.cn/yun/94061.html
摘要:讓應用程序擁有異步讀取存儲在用戶計算機上文件或原始數據緩沖區(qū)的能力,使用或對象指定要讀取的文件或數據。對象用來表示通用的固定長度的原始二進制數據緩沖區(qū)。事實上,沒有名為的全局對象,也沒有一個名為的構造函數。 Ajax 即 Asynchronous Javascript And XML (異步 JavaScript 和 XML),是指一種創(chuàng)建交互式網頁應用的網頁開發(fā)技術。在無需重新加載整...
摘要:接收響應當請求發(fā)送到服務器端,收到響應后,響應的數據會自動填充對象的屬性。一般而已狀態(tài)代碼為作為成功的標志。必要時,可以將查詢字符串參數追加到的末尾,以便提交給服務器。后端實現可以自學一點后端知識,便于學習。 前端學習:教程&開發(fā)模塊化/規(guī)范化/工程化/優(yōu)化&工具/調試&值得關注的博客/Git&面試-前端資源匯總 歡迎提issues斧正:Ajax JavaScript-Ajax&&no...
摘要:為了解救上面說到的問題是向提交的一個草案,旨在推出一套標準的,其基本功能是實現用對本地文件進行操作。出于安全性的考慮,該只對本地文件提供有限的訪問。 系列文章 關于前端上傳文件全面基礎掃盲貼(零)關于前端上傳文件全面基礎掃盲貼(一) ----- XMLHttpRequest關于前端上傳文件全面基礎掃盲貼(二) ----- File關于前端上傳文件全面基礎掃盲貼(三) ----- For...
閱讀 1166·2021-10-15 09:39
閱讀 3070·2021-09-10 10:50
閱讀 3463·2019-08-30 15:53
閱讀 1890·2019-08-30 15:52
閱讀 2577·2019-08-29 15:31
閱讀 1985·2019-08-26 13:43
閱讀 2606·2019-08-26 13:37
閱讀 1449·2019-08-23 18:31