亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

HTML5 文件上傳下載的實例代碼

2024-09-05 07:22:01
字體:
來源:轉載
供稿:網友

前言

HTML5 中提供的文件API在前端中有著豐富的應用,上傳、下載、讀取內容等在日常的交互中很常見。而且在各個瀏覽器的兼容也比較好,包括移動端,除了 IE 只支持 IE10 以上的版本。想要更好地掌握好操作文件的功能,先要熟悉每個API。

FileList 對象和 file 對象

HTML 中的 input[type="file"] 標簽有個 multiple 屬性,允許用戶選擇多個文件,FileList對象則就是表示用戶選擇的文件列表。這個列表中的每一個文件,就是一個 file 對象。

  1. file 對象的屬性:
  2. name : 文件名,不包含路徑。
  3. type : 文件類型。圖片類型的文件都會以 image/ 開頭,可以由此來限制只允許上傳圖片。
  4. size : 文件大小??梢愿鶕募笮磉M行其他操作。
  5. 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 并且文件大小小于 200kb            if(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-5eb16b38ba36    var 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();

該對象有以下方法:

  1. abort:中斷讀取操作。
  2. readAsArrayBuffer:讀取文件內容到ArrayBuffer對象中。
  3. readAsBinaryString:將文件讀取為二進制數據。
  4. readAsDataURL:將文件讀取為data: URL格式的字符串。
  5. readAsText:將文件讀取為文本。

上傳圖片預覽

在常見的應用就是在客戶端上傳圖片之后通過 readAsDataURL() 來顯示圖片。

<input type="file" id="files" accept="image/jpeg,image/jpg,image/png"><img src="blank.gif" id="preview"><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 = "https://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);     // 哈嘍 世界

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人黄色av| 欧美国产第二页| 国产小视频国产精品| 97超碰色婷婷| 中文字幕在线看视频国产欧美| 日韩av综合网| 国产精品视频久久久久| 久久久久久久国产| 亚洲激情在线观看视频免费| 成人网中文字幕| 精品久久中文字幕久久av| 亚洲va国产va天堂va久久| 亚洲精品电影久久久| 国产欧美精品一区二区三区介绍| 亚洲精品色婷婷福利天堂| 亚洲成色999久久网站| 日韩在线小视频| 91日韩在线播放| 国产偷国产偷亚洲清高网站| 九九久久久久久久久激情| 57pao国产成人免费| 欧美黄网免费在线观看| 国产性色av一区二区| 亚洲视频在线观看免费| 国产精品久久久久aaaa九色| 欧美电影在线免费观看网站| 亚洲精品欧美日韩专区| 97香蕉久久超级碰碰高清版| 国产精品久久久久免费a∨| 日韩精品极品在线观看播放免费视频| 最近中文字幕2019免费| 欧美国产日韩一区| 欧美大全免费观看电视剧大泉洋| 国产情人节一区| 亚洲一区二区黄| 成人亚洲综合色就1024| 伦伦影院午夜日韩欧美限制| 97视频网站入口| 亚洲美女av黄| 久久99久国产精品黄毛片入口| 中文字幕av一区二区三区谷原希美| 成人免费网站在线观看| 中文在线不卡视频| 国产91在线播放九色快色| 亚洲人成在线观| 日本欧美中文字幕| 欧美国产乱视频| 国产精品久久久久久久久久| 国产精自产拍久久久久久| 欧美日韩在线免费| 国产精品久久久久秋霞鲁丝| 久久久91精品| 隔壁老王国产在线精品| 国产成人久久久精品一区| 欧美怡红院视频一区二区三区| 成人激情在线观看| 国产精品视频永久免费播放| 亚洲成人精品av| 国产一区深夜福利| 国产一区二区三区18| 欧美激情奇米色| 欧美精品在线免费观看| 国产欧美一区二区| 欧美大片在线看| 欧美色视频日本高清在线观看| 国产精品欧美在线| 亚洲码在线观看| 国产精品成人播放| 亚洲日韩中文字幕| 欧美成人免费va影院高清| 日韩av综合网站| 日韩视频免费大全中文字幕| 亚洲欧美精品suv| 欧美一级大片视频| 欧美亚洲成人xxx| 97国产在线视频| 国产日韩精品一区二区| 综合欧美国产视频二区| 57pao精品| xvideos成人免费中文版| 国产91精品网站| 国产一区二区三区视频在线观看| 欧美日产国产成人免费图片| 97久久精品人人澡人人爽缅北| 欧美日韩中文字幕在线视频| 富二代精品短视频| 国产精品视频最多的网站| 18性欧美xxxⅹ性满足| 久久久视频精品| 亚洲爱爱爱爱爱| 米奇精品一区二区三区在线观看| 91大神在线播放精品| 国产精品视频网站| 欧美一级高清免费播放| 中文字幕日韩欧美在线视频| 久久好看免费视频| 亚洲视频自拍偷拍| 国产伦精品一区二区三区精品视频| 亚洲sss综合天堂久久| 在线观看国产成人av片| 国产精品久久久久久久美男| 欧美日韩激情视频| 久久精品视频网站| 日韩动漫免费观看电视剧高清| 亚洲电影av在线| 欧美成人一二三| 精品国产91久久久久久老师| 欧美视频在线观看免费网址| 亚洲伊人一本大道中文字幕| 国产精品入口福利| 精品动漫一区二区| 日韩免费不卡av| 深夜精品寂寞黄网站在线观看| 全亚洲最色的网站在线观看| 日韩免费电影在线观看| 性金发美女69hd大尺寸| 高清欧美一区二区三区| 日韩在线中文字| 91久久在线播放| 一级做a爰片久久毛片美女图片| 亚洲裸体xxxx| 亚洲激情第一页| 欧美精品激情在线观看| …久久精品99久久香蕉国产| 91嫩草在线视频| 成人黄色午夜影院| 2019中文在线观看| 黄色91在线观看| 成人写真视频福利网| 国产精品日韩电影| 91在线视频免费| 久久精品免费电影| 精品福利一区二区| 国产精品扒开腿做爽爽爽的视频| 亚洲高清一二三区| 亚洲高清一二三区| 精品一区二区三区三区| 2019av中文字幕| 免费97视频在线精品国自产拍| 一本一本久久a久久精品牛牛影视| 国产精品电影观看| 91chinesevideo永久地址| 91亚洲国产精品| 亚洲电影免费观看高清完整版在线| 乱亲女秽乱长久久久| 亚洲成人xxx| 日本伊人精品一区二区三区介绍| 日韩中文字幕av| 久久精品99久久久香蕉| 日韩黄色高清视频| 欧美性猛交xxxx免费看| 日韩中文字幕网| 亚洲韩国欧洲国产日产av| 欧美疯狂性受xxxxx另类| 91精品视频在线免费观看| 国产日韩欧美黄色| 欧美日韩精品在线| 欧美极品美女电影一区| 亚洲欧美日韩直播| 欧美成年人视频网站| 欧美性高潮在线| 日韩视频精品在线| 欧美理论在线观看| 亚洲视频专区在线|