濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > 基于HTML5 FileSystem API的使用介紹

基于HTML5 FileSystem API的使用介紹

熱門標(biāo)簽:四川移動(dòng)電銷外呼客戶管理系統(tǒng) 400開頭的電話好申請(qǐng)不 百度地圖標(biāo)注為什么總是封號(hào) 小朱地圖標(biāo)注 咸陽(yáng)穩(wěn)定外呼系統(tǒng)軟件 怎么做百度地圖標(biāo)注 地圖標(biāo)注柱狀圖 智能芯電話機(jī)器人 臨海地圖標(biāo)注app

HTML5的強(qiáng)大之一就是允許web程序申請(qǐng)一些臨時(shí)或者永久的空間(Quota)在這里可以進(jìn)行 數(shù)據(jù)的存儲(chǔ)甚至文件的操作。

FileSystem提供了文件夾和文件的創(chuàng)建、移動(dòng)、刪除等操作,大大方便了數(shù)據(jù)的本地處理, 而且所有的數(shù)據(jù)都是在沙盒(sandboxed)中,不同的web程序不能互相訪問,這就保證了數(shù)據(jù) 的完整和安全。

在CatWrite項(xiàng)目中,運(yùn)用了HTML5的這個(gè)特性進(jìn)行數(shù)據(jù)的存儲(chǔ),很是方便,只是目前來(lái)說只有 Chrome瀏覽器對(duì)FileSystem API支持的比較好,所以只能運(yùn)行在Chrome瀏覽器中。

在完成這個(gè)功能的時(shí)候,查閱了很多資料,有一些資料是一年前的,但是隨著瀏覽器版本的 變化,一些代碼已經(jīng)老化,在這里一一總結(jié)和整理。這里只列舉了項(xiàng)目中用到的API,算是 對(duì)完成功能的一次梳理。

申請(qǐng)空間
為了進(jìn)行數(shù)據(jù)的存儲(chǔ),必須要向?yàn)g覽器進(jìn)行申請(qǐng),如果是永久存儲(chǔ)還會(huì)向用戶進(jìn)行詢問,只有 同意后才會(huì)繼續(xù)執(zhí)行。

首先必須要聲明想要的權(quán)限。

復(fù)制代碼
代碼如下:

window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem; //文件系統(tǒng)請(qǐng)求標(biāo)識(shí)
window.resolveLocalFileSystemURL = window.resolveLocalFileSystemURL || window.webkitResolveLocalFileSystemURL; //根據(jù)URL取得文件的讀取權(quán)限

得到系統(tǒng)的權(quán)限后就可以向?yàn)g覽器申請(qǐng)空間

復(fù)制代碼
代碼如下:

window.requestFileSystem(window.PERSISTENT, //persistent(永久) or temporary(臨時(shí))
1024*1024, //1M
onInitFs, //成功后的回調(diào)函數(shù)
errorHandler); //錯(cuò)誤后的回調(diào)函數(shù)

回調(diào)函數(shù)

復(fù)制代碼
代碼如下:

function onInitFs(fs){
fs.root.getDirectory('catwrite_documents', {create: true}, function(dirEntry) {
console.log('You have just created the ' + dirEntry.name + ' directory.');
}, errorHandler);
}
//錯(cuò)誤回調(diào)
function errorHandler(err){
var msg = 'An error occured: ';
switch (err.code) {
case FileError.NOT_FOUND_ERR:
msg += 'File or directory not found';
break;
case FileError.NOT_READABLE_ERR:
msg += 'File or directory not readable';
break;
case FileError.PATH_EXISTS_ERR:
msg += 'File or directory already exists';
break;
case FileError.TYPE_MISMATCH_ERR:
msg += 'Invalid filetype';
break;
default:
msg += 'Unknown Error';
break;
};
console.log(msg + err);
}

如果成功后悔調(diào)用OnInitFs回調(diào)函數(shù),在里面用了getDirectory方法用來(lái)創(chuàng)建一個(gè)文件夾,這下面再說。

但是這是有個(gè)問題,這樣做的話每次加載頁(yè)面都會(huì)申請(qǐng),這肯定不是我們想要的,我們要 的是在有數(shù)據(jù)的時(shí)候就可以讀取數(shù)據(jù)。

判斷是否申請(qǐng)過空間
所以我們需要讀取瀏覽器的數(shù)據(jù),看看是否已有存儲(chǔ)。這就用到了另一個(gè)API:

復(fù)制代碼
代碼如下:

void queryUsageAndQuota(
in DOMString url,
in EntryCallback successCallback,
in optional ErrorCallback errorCallback
);

這個(gè)API可以查詢當(dāng)前web的空間情況,如果成功的話就會(huì)調(diào)用successCallback回調(diào)函數(shù) 并把已用空間和全部空間作為參數(shù)傳入方法中。如果失敗則調(diào)去errorCallback。

復(fù)制代碼
代碼如下:

window.webkitStorageInfo.queryUsageAndQuota(webkitStorageInfo.PERSISTENT,
function(used, remaining){
if(remaining == ""){
console.log("未申請(qǐng)空間。");
}else{
console.log("已使用空間"+used);
console.log("全部空間"+remaining);
}
},
errorHandler); </p> <p>

我們可以通過判斷remaining參數(shù)來(lái)判斷是否有申請(qǐng)空間,如果沒有申請(qǐng),則返回上一步申請(qǐng)空間。 如果已經(jīng)有空間的話,則需要得到空間的跟文件,這樣才能操作數(shù)據(jù)。

獲取文件入口
FileSystem使用了特殊的文件系統(tǒng)和沙盒模式,在電腦上或者其他web中是無(wú)法訪問沙盒中的文件的 ,只能用對(duì)應(yīng)的格式去訪問。

在瀏覽器中輸入:

?filesystem:http://catcoder.com/persistent/
  

這樣可以訪問catcoder.com這個(gè)網(wǎng)站在本機(jī)永久數(shù)據(jù),把persistent換成temporary則是讀取臨時(shí)空間。

然后我們就可以通過URL和對(duì)應(yīng)API獲取文件的入口(Lets you look up the entry for a file or directory with a local URL)。

復(fù)制代碼
代碼如下:

void resolveLocalFileSystemURL(
in DOMString url,
in EntryCallback successCallback,
in optional ErrorCallback errorCallback
);

下面就可以讀取本機(jī)存儲(chǔ)的數(shù)據(jù)了

復(fù)制代碼
代碼如下:

var url = "filesystem:http://" + window.location.host + "/persistent/catwrite_documents/";
window.resolveLocalFileSystemURL(url,function(fileEntry){
console.log(fileEntry);
var dirReader = fileEntry.createReader();
var readEntries = function(){
dirReader.readEntries(function(results){
if(!results.length){
create_file_title("默認(rèn)文件", "");
console.log("沒有文件!");
}else{
console.log("讀取到" + results.length + "個(gè)文件");
for(var i = 0; i < results.length; i++){
console.log(results[i].name);
getFileContentByName(fileEntry, results[i].name);
}
}
},errorHandler);
};
readEntries();
},errorHandler);

標(biāo)簽:南平 山南 平頂山 黃石 陜西 黃石 公主嶺

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《基于HTML5 FileSystem API的使用介紹》,本文關(guān)鍵詞  基于,HTML5,FileSystem,API,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《基于HTML5 FileSystem API的使用介紹》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于基于HTML5 FileSystem API的使用介紹的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    西吉县| 探索| 临城县| 荔浦县| 越西县| 阳东县| 弋阳县| 华池县| 茶陵县| 平舆县| 南和县| 堆龙德庆县| 徐闻县| 阜新市| 潼南县| 保定市| 民权县| 彰化县| 体育| 正蓝旗| 鹿邑县| 蓝山县| 垦利县| 大足县| 修文县| 桃园县| 咸阳市| 肃宁县| 远安县| 通化县| 轮台县| 威信县| 阿城市| 四平市| 勐海县| 孟州市| 土默特左旗| 龙胜| 辽源市| 井冈山市| 大英县|