前言
HTML5 中提供的檔案API在前端中有著豐富的應用,上傳、下載、讀取內容等在日常的互動中很常見。而且在各個瀏覽器的相容也比較好,包括行動端,除了 IE 只支援 IE10 以上的版本。想要更掌握好操作文件的功能,先要熟悉每個API。
原文作者:林鑫,作者部落格:
FileList 物件與file 物件
HTML 中的input[type="file"] 標籤有個multiple 屬性,允許使用者選擇多個文件,FileList物件就是表示使用者選擇的文件清單。這個清單中的每一個文件,就是一個 file 物件。
file 物件的屬性:
name : 檔名,不包含路徑。
type : 檔案類型。圖片類型的檔案都會以 image/ 開頭,可以由此來限制只允許上傳圖片。
size : 檔案大小。可以根據檔案大小來進行其他操作。
lastModified : 檔案最後修改的時間。
<input type="file" id="files" multiple><script>var elem = document.getElementById('files');elem.onchange = function (event) {var files = event.target.files;for (var i = 0; i < files.length; i++) {// 文件类型为 image 并且文件大小小于 200kbif(files[i].type.indexOf('image/') !== -1 && files[i].size < 204800){console.log(files[i].name);}}}</script>
input 中有個 accept 屬性,可以用來規定能夠透過檔案上傳提交的檔案類型。
accept="image/*" 可以用來限制只允許上傳映像格式。但在 Webkit 瀏覽器下卻出現了回應滯慢的問題,要等上好幾秒才彈出檔案選擇框。
解決方法就是將 * 通配符改為指定的 MIME 類型。
<input type="file" accept="image/gif,image/jpeg,image/jpg,image/png">
Blob 物件
Blob 物件相當於一個容器,可以用來存放二進位資料。它有兩個屬性,size 屬性表示位元組長度,type 屬性表示 MIME 類型。
如何建立
Blob 物件可以使用 Blob() 建構子來建立。
var blob = new Blob(['hello'], {type:"text/plain"});
Blob 建構子中的第一個參數是一個數組,可以存放 ArrayBuffer物件、ArrayBufferView 物件、Blob物件和字串。
Blob 物件可以透過 slice() 方法來傳回一個新的 Blob 物件。
var newblob = blob.slice(0,5, {type:"text/plain"});
slice() 方法使用三個參數,皆為可選。第一個參數代表要從Blob物件中的二進位資料的起始位置開始複製,第二個參數代表複製的結束位置,第三個參數為 Blob 物件的 MIME 類型。
canvas.toBlob() 也可以建立 Blob 物件。 toBlob() 使用三個參數,第一個為回呼函數,第二個為圖片類型,預設為 image/png,第三個為圖片質量,值在0到1之間。
var canvas = document.getElementById('canvas');canvas.toBlob(function(blob){ console.log(blob); }, "image/jpeg", 0.5);
下載檔案
Blod 物件可以透過 window.URL 物件產生一個網路位址,結合 a 標籤的 download 屬性來實現下載檔案功能。
例如把 canvas 下載為一個圖片檔。
var canvas = document.getElementById('canvas');canvas.toBlob(function(blob){// 使用 createObjectURL 生成地址,格式为 blob:null/fd95b806-db11-4f98-b2ce-5eb16b38ba36var url = URL.createObjectURL(blob);var a = document.createElement('a');a.download = 'canvas';a.href = url;// 模拟a标签点击进行下载a.click();// 下载后告诉浏览器不再需要保持这个文件的引用了URL.revokeObjectURL(url);});
也可以將字串儲存為文字文件,方法類似。
FileReader 物件
FileReader 物件主要用來把檔案讀入內存,並且讀取檔案中的資料。透過建構函式建立一個 FileReader 物件
var reader = new FileReader();
該物件有以下方法:
abort:中斷讀取操作。
readAsArrayBuffer:讀取檔案內容到ArrayBuffer物件中。
readAsBinaryString:將檔案讀取為二進位資料。
readAsDataURL:將檔案讀取為data: URL格式的字串。
readAsText:將檔案讀取為文字。
上傳圖片預覽
在常見的應用程式就是在用戶端上傳圖片之後透過 readAsDataURL() 來顯示圖片。
<input type="file" id="files" accept="image/jpeg,image/jpg,image/png"><img src="/static/imghwm/default1.png" data-src="blank.gif" class="lazy" id="preview" alt="h5中檔案上傳下載實例" ><script>var elem = document.getElementById('files'),img = document.getElementById('preview');elem.onchange = function () {var files = elem.files,reader = new FileReader();if(files && files[0]){reader.onload = function (ev) {img.src = ev.target.result;}reader.readAsDataURL(files[0]);}}</script>
但在某些手機上豎起拍照上傳照片時會有bug,會發現照片倒了,包括三星和iPhone。 。 。解決方案這裡不做講解,有興趣可以查看:移動端圖片上傳旋轉、壓縮的解決方案
數據備份與恢復
FileReader 對象的readAsText() 可以讀取文件的文本,結合Blob 物件下載檔案的功能,那就可以實現將資料匯出檔案備份到本地,當資料要恢復時,透過input 把備份檔案上傳,使用readAsText() 讀取文本,恢復資料。
程式碼跟上面功能類似,這裡不重複,具體的應用可以參考:notepad
Base64 編碼
#在HTML5 中新增了atob 和btoa 方法來支援Base64編碼。它們的命名也很簡單,b to a 和 a to b,即代表編碼和解碼。
var a = "lin-xin.github.io";var b = btoa(a);var c = atob(b);console.log(a); // https://lin-xin.github.ioconsole.log(b); // aHR0cHM6Ly9saW4teGluLmdpdGh1Yi5pbw==console.log(c); // https://lin-xin.github.io
btoa 方法對字串 a 進行編碼,不會改變 a 的值,傳回一個編碼後的值。
atob 方法對編碼後的字串進行解碼。
但是參數中帶中文,已經超出了8位ASCII編碼的字元範圍,瀏覽器就會報錯。所以需要先對中文進行 encodeURIComponent 編碼處理。
var a = "哈喽 世界";var b = btoa(encodeURIComponent(a));var c = decodeURIComponent(atob(b));console.log(b); // JUU1JTkzJTg4JUU1JTk2JUJEJTIwJUU0JUI4JTk2JUU3JTk1JThDconsole.log(c); // 哈喽 世界
以上是h5中檔案上傳下載實例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Web标准和技术从HTML4、CSS2和简单的JavaScript演变至今,经历了显著的发展。1)HTML5引入了Canvas、WebStorage等API,增强了Web应用的复杂性和互动性。2)CSS3增加了动画和过渡功能,使页面效果更加丰富。3)JavaScript通过Node.js和ES6的现代化语法,如箭头函数和类,提升了开发效率和代码可读性,这些变化推动了Web应用的性能优化和最佳实践的发展。

H5不僅僅是HTML5的簡稱,它代表了一個更廣泛的現代網頁開發技術生態:1.H5包括HTML5、CSS3、JavaScript及相關API和技術;2.它提供更豐富、互動、流暢的用戶體驗,能在多設備上無縫運行;3.使用H5技術棧可以創建響應式網頁和復雜交互功能。

H5與HTML5指的是同一個東西,即HTML5。 HTML5是HTML的第五個版本,帶來了語義化標籤、多媒體支持、畫布與圖形、離線存儲與本地存儲等新功能,提升了網頁的表現力和交互性。

H5referstoHTML5,apivotaltechnologyinwebdevelopment.1)HTML5introducesnewelementsandAPIsforrich,dynamicwebapplications.2)Itsupportsmultimediawithoutplugins,enhancinguserexperienceacrossdevices.3)SemanticelementsimprovecontentstructureandSEO.4)H5'srespo

H5開發需要掌握的工具和框架包括Vue.js、React和Webpack。 1.Vue.js適用於構建用戶界面,支持組件化開發。 2.React通過虛擬DOM優化頁面渲染,適合複雜應用。 3.Webpack用於模塊打包,優化資源加載。

HTML5hassignificantlytransformedwebdevelopmentbyintroducingsemanticelements,enhancingmultimediasupport,andimprovingperformance.1)ItmadewebsitesmoreaccessibleandSEO-friendlywithsemanticelementslike,,and.2)HTML5introducednativeandtags,eliminatingthenee

H5通過語義化元素和ARIA屬性提升網頁的可訪問性和SEO效果。 1.使用、、等元素組織內容結構,提高SEO。 2.ARIA屬性如aria-label增強可訪問性,輔助技術用戶可順利使用網頁。

"h5"和"HTML5"在大多數情況下是相同的,但它們在某些特定場景下可能有不同的含義。 1."HTML5"是W3C定義的標準,包含新標籤和API。 2."h5"通常是HTML5的簡稱,但在移動開發中可能指基於HTML5的框架。理解這些區別有助於在項目中準確使用這些術語。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

Atom編輯器mac版下載
最受歡迎的的開源編輯器

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

禪工作室 13.0.1
強大的PHP整合開發環境

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中