基于HTML5 FileSystem API的使用介紹
來(lái)源:易賢網(wǎng) 閱讀:1694 次 日期:2016-07-13 15:42:52
溫馨提示:易賢網(wǎng)小編為您整理了“基于HTML5 FileSystem API的使用介紹”,方便廣大網(wǎng)友查閱!

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

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

在CatWrite項(xiàng)目中,運(yùn)用了HTML5的這個(gè)特性進(jìn)行數(shù)據(jù)的存儲(chǔ),很是方便,只是目前來(lái)說(shuō)只有 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ì)向用戶(hù)進(jìn)行詢(xún)問(wèn),只有 同意后才會(huì)繼續(xù)執(zhí)行。

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

代碼如下:

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)空間

代碼如下:

window.requestFileSystem(window.PERSISTENT, //persistent(永久) or temporary(臨時(shí))

1024*1024, //1M

onInitFs, //成功后的回調(diào)函數(shù)

errorHandler); //錯(cuò)誤后的回調(diào)函數(shù)

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

代碼如下:

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è)文件夾,這下面再說(shuō)。

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

判斷是否申請(qǐng)過(guò)空間

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

代碼如下:

void queryUsageAndQuota(

in DOMString url,

in EntryCallback successCallback,

in optional ErrorCallback errorCallback

);

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

代碼如下:

window.webkitStorageInfo.queryUsageAndQuota(webkitStorageInfo.PERSISTENT,

function(used, remaining){

if(remaining == ""){

console.log("未申請(qǐng)空間。");

}else{

console.log("已使用空間"+used);

console.log("全部空間"+remaining);

}

},

errorHandler); </p> <p>

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

獲取文件入口

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

在瀏覽器中輸入:

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

  

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

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

代碼如下:

void resolveLocalFileSystemURL(

in DOMString url,

in EntryCallback successCallback,

in optional ErrorCallback errorCallback

);

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

代碼如下:

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("沒(méi)有文件!");

}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);

更多信息請(qǐng)查看網(wǎng)頁(yè)制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:基于HTML5 FileSystem API的使用介紹
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢(xún)回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢(xún)?yōu)闇?zhǔn)!
相關(guān)閱讀網(wǎng)頁(yè)制作

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢(xún) | 簡(jiǎn)要咨詢(xún)須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話(huà):0871-65099533/13759567129 獲取招聘考試信息及咨詢(xún)關(guān)注公眾號(hào):hfpxwx
咨詢(xún)QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)