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

首頁 > 編程 > JavaScript > 正文

JavaScript中讀取和保存文件實例

2019-11-20 20:43:21
字體:
來源:轉載
供稿:網友

話說今天只是粗略瀏覽了一下Proxy SwitchySharp的源碼,就收獲了不少東西,其中就包括本文要介紹的讀取和保存文件。

因為Google還不提供同步插件數據的功能,所以導入和導出插件配置就必須和文件打交道了。而出于安全原因,只有IE才提供訪問文件的API;但隨著HTML 5的到來,其他瀏覽器也紛紛支持了。

首先說讀取文件。W3C提供了一些File API,其中最重要的是FileReader這個類。

先列出需要用到的HTML標簽:

復制代碼 代碼如下:
<input type="file" id="file" onchange="handleFiles(this.files)"/>

當選擇了一個文件時,就會把包含這個文件的列表(一個FileList對象)作為參數傳給handleFiles()函數了。
這個FileList對象類似一個數組,可以知道文件的數目,而它的元素就是File對象了。
從這個File對象可以獲取name、size、lastModifiedDate和type等屬性。
把這個File對象傳給FileReader對象的讀取方法,就能讀取文件了。


FileReader共有4種讀取方法:
1.readAsArrayBuffer(file):將文件讀取為ArrayBuffer。
2.readAsBinaryString(file):將文件讀取為二進制字符串
3.readAsDataURL(file):將文件讀取為Data URL
4.readAsText(file, [encoding]):將文件讀取為文本,encoding缺省值為'UTF-8'
此外,abort()方法可以停止讀取文件。


FileReader對象在讀取文件后,還需要進行處理。為了不阻塞當前線程,API采用了事件模型,可以注冊這些事件:
1.onabort:中斷時觸發
2.onerror:出錯時觸發
3.onload:文件成功讀取完畢時觸發
4.onloadend:文件讀取完畢時觸發,無論是否失敗
5.onloadstart:文件開始讀取時觸發
6.onprogress:當文件讀取時,周期性地觸發

有了這些方法以后,就可以處理文件了。
先來試試讀取文本文件:

復制代碼 代碼如下:

function handleFiles(files) {
    if (files.length) {
        var file = files[0];
        var reader = new FileReader();
        if (/text///w+/.test(file.type)) {
            reader.onload = function() {
                $('<pre>' + this.result + '</pre>').appendTo('body');
            }
            reader.readAsText(file);
        }
    }
}


這里的this.result實際上就是reader.result,也就是讀取出來的文件內容。
測試一下你會發現這個文件的內容被添加到網頁中了。如果是用Chrome的話,必須把網頁放在服務器上或插件里,file協議下會失敗。

再來試試圖片,因為瀏覽器可以直接顯示Data URI協議的圖片,所以這次就添加圖片:

復制代碼 代碼如下:

function handleFiles(files) {
    if (files.length) {
        var file = files[0];
        var reader = new FileReader();
        if (/text///w+/.test(file.type)) {
            reader.onload = function() {
                $('<pre>' + this.result + '</pre>').appendTo('body');
            }
            reader.readAsText(file);
        } else if(/image///w+/.test(file.type)) {
            reader.onload = function() {
                $('<img src="' + this.result + '"/>').appendTo('body');
            }
            reader.readAsDataURL(file);
        }
    }
}

其實input:file控件還支持選擇多個文件:

復制代碼 代碼如下:

<input type="file" id="files" multiple="" onchange="handleFiles(this.files)"/>

這樣handleFiles()里就需要遍歷處理files了。

如果只想讀取部分數據的話,File對象還有webkitSlice()或mozSlice()方法,用于生成Blob對象。這個對象可以和File對象一樣被FileReader讀取。這2個方法接收3個參數:第1個參數是起始位置;第2個是結束位置,省略時則讀到文件結尾;第3個是content type。
例子可以參考《Reading local files in JavaScript》。

當然,除了導入數據和顯示文件以外,它還可以用來做AJAX上傳,代碼可以參考《Using files from web applications》。


接下來說保存文件。
實際上File API: Writer提供了4個接口,但目前只有部分瀏覽器(Chrome 8+和Firefox 4+)實現了BlobBuilder,其余接口都不可用。
對于不支持的瀏覽器,可以使用BlobBuilder.js和FileSaver.js來獲得支持。
我研究了一下,發現了其中的奧秘。

BlobBuilder可以創建一個Blob對象。把這個Blob對象傳遞給URL.createObjectURL()方法,就可以拿到一個object URL。而這個object URL就是這個Blob對象的下載地址。
拿到下載地址后,創建一個a元素,將下載地址賦值給href屬性,文件名賦值給download屬性(Chrome 14+支持)。
然后再創建一個click事件,交給這個a元素處理,就會導致瀏覽器開始下載這個Blob對象了。
最后,用URL.revokeObjectURL()來釋放這個object URL,通知瀏覽器可以不必繼續引用這個文件了。

下面就是一段化簡的代碼:

復制代碼 代碼如下:

var BlobBuilder = BlobBuilder || WebKitBlobBuilder || MozBlobBuilder;
var URL = URL || webkitURL || window;

function saveAs(blob, filename) {
    var type = blob.type;
    var force_saveable_type = 'application/octet-stream';
    if (type && type != force_saveable_type) { // 強制下載,而非在瀏覽器中打開
        var slice = blob.slice || blob.webkitSlice || blob.mozSlice;
        blob = slice.call(blob, 0, blob.size, force_saveable_type);
    }

    var url = URL.createObjectURL(blob);
    var save_link = document.createElementNS('http://www.w3.org/1999/xhtml', 'a');
    save_link.href = url;
    save_link.download = filename;

    var event = document.createEvent('MouseEvents');
    event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
    save_link.dispatchEvent(event);
    URL.revokeObjectURL(url);
}

var bb = new BlobBuilder;
bb.append('Hello, world!');
saveAs(bb.getBlob('text/plain;charset=utf-8'), 'hello world.txt');


測試時會提示保存一個文本文件。Chrome需要把網頁放在服務器上或插件里。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品美乳一区二区免费| 日日摸夜夜添一区| 久久久国产精彩视频美女艺术照福利| 日韩在线观看电影| 国产成人福利网站| 亚洲成人动漫在线播放| 2018国产精品视频| 日韩精品一二三四区| 欧美激情区在线播放| 国产午夜精品视频| 国产中文字幕日韩| 色婷婷久久一区二区| 精品日韩视频在线观看| 日韩电影免费观看在线| 亚洲精品97久久| 欧美在线视频网站| 91久久国产精品| 久久成人精品一区二区三区| 国产精品日韩欧美综合| 亚洲aⅴ日韩av电影在线观看| 91免费精品国偷自产在线| 538国产精品一区二区在线| 亚洲自拍高清视频网站| 91精品国产91久久久久久最新| 日韩经典一区二区三区| 久久久最新网址| 色噜噜国产精品视频一区二区| 国产精品爱久久久久久久| 亚洲九九九在线观看| 精品在线观看国产| 久久成年人免费电影| 色噜噜狠狠狠综合曰曰曰88av| 国产精品久久久久久av福利| 国产精品美女在线| 精品国产老师黑色丝袜高跟鞋| 亚洲精品suv精品一区二区| 久久成人一区二区| 国产精品av在线| 国产精品成人v| 91精品国产色综合| 精品国产一区二区三区久久久狼| 综合网日日天干夜夜久久| 久久久精品影院| 操人视频在线观看欧美| 亚洲精品成人久久久| 最近2019年中文视频免费在线观看| 日本中文字幕成人| 5566日本婷婷色中文字幕97| 日韩欧美亚洲一二三区| 精品久久久香蕉免费精品视频| 国产精品黄色影片导航在线观看| 国产一区二区欧美日韩| 久久影视电视剧免费网站| 国产日韩欧美视频在线| 欧美国产日本在线| 欧美巨大黑人极品精男| 91在线精品视频| 国产精品丝袜视频| 国产大片精品免费永久看nba| 欧美激情久久久久久| 国产精品久久久久久久久久久久| 国产一区香蕉久久| 久久综合久久美利坚合众国| 国产精品极品尤物在线观看| 91最新在线免费观看| 91免费观看网站| 中文精品99久久国产香蕉| 中文字幕亚洲综合| 色先锋资源久久综合5566| 成人激情电影一区二区| 国产a∨精品一区二区三区不卡| 亚洲精品美女在线观看播放| 国产精品激情av电影在线观看| 亚洲精品天天看| 成人97在线观看视频| 日韩亚洲欧美成人| 午夜美女久久久久爽久久| 成人乱人伦精品视频在线观看| 欧美一区二粉嫩精品国产一线天| 欧美成人精品在线观看| 亚洲日本成人女熟在线观看| 5566成人精品视频免费| 久久精品久久久久电影| 九九九热精品免费视频观看网站| 国产精品久久久久99| 久久精品视频中文字幕| 亚洲色图综合久久| 日韩精品久久久久久久玫瑰园| 亚洲精品日韩欧美| 韩日精品中文字幕| 国产69精品久久久久9| 久久精彩免费视频| 日本中文字幕久久看| 久久久在线免费观看| 欧美激情亚洲综合一区| 日韩免费观看高清| 久久香蕉国产线看观看网| 国产精品网站视频| 欧美性生活大片免费观看网址| 精品视频久久久| 日本久久中文字幕| 亚洲sss综合天堂久久| 国产精品视频自在线| 亚洲激情自拍图| 91欧美精品午夜性色福利在线| 欧美精品免费播放| 亚洲福利在线播放| 综合欧美国产视频二区| 日韩成人av在线| 国产视频精品自拍| 国内精品久久久久久| 欧美日韩综合视频网址| 狠狠做深爱婷婷久久综合一区| 日韩av影视综合网| 国产精品av免费在线观看| 国产精品久久久久久久久久小说| 精品亚洲国产视频| 亚洲欧美成人精品| 国产精品免费在线免费| 精品国产福利在线| 成人精品一区二区三区电影免费| 亚洲精品永久免费精品| 91在线精品视频| 国产成人avxxxxx在线看| 久久亚洲精品一区二区| 国产在线精品成人一区二区三区| 在线精品播放av| 日本久久久a级免费| 国产精品吊钟奶在线| 久久亚洲电影天堂| 国产精品视频一区国模私拍| 神马国产精品影院av| 海角国产乱辈乱精品视频| 久久综合五月天| 国内精久久久久久久久久人| 亚洲jizzjizz日本少妇| 国产成人小视频在线观看| 国产深夜精品福利| 欧美高清无遮挡| 欧美日韩性生活视频| 久热99视频在线观看| 国产情人节一区| 精品亚洲aⅴ在线观看| 日韩欧美一区二区三区久久| 亚洲欧美综合区自拍另类| 91超碰caoporn97人人| 亚洲自拍av在线| 欧美日韩国产成人在线| 欧美一级淫片丝袜脚交| 国模精品一区二区三区色天香| 欧美在线视频一二三| 久久成人精品一区二区三区| 国产精品福利网站| 在线观看日韩www视频免费| 538国产精品一区二区免费视频| 久久亚洲欧美日韩精品专区| 欧美做爰性生交视频| 中文一区二区视频| 国产精品日韩欧美综合| 久久精品国产成人精品| 91精品啪在线观看麻豆免费| 国产一区二区三区在线播放免费观看| 26uuu亚洲伊人春色| 日韩经典一区二区三区|