婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 基于HTML5 FileSystem API的使用介紹

基于HTML5 FileSystem API的使用介紹

熱門標簽:四川移動電銷外呼客戶管理系統 400開頭的電話好申請不 百度地圖標注為什么總是封號 小朱地圖標注 咸陽穩定外呼系統軟件 怎么做百度地圖標注 地圖標注柱狀圖 智能芯電話機器人 臨海地圖標注app

HTML5的強大之一就是允許web程序申請一些臨時或者永久的空間(Quota)在這里可以進行 數據的存儲甚至文件的操作。

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

在CatWrite項目中,運用了HTML5的這個特性進行數據的存儲,很是方便,只是目前來說只有 Chrome瀏覽器對FileSystem API支持的比較好,所以只能運行在Chrome瀏覽器中。

在完成這個功能的時候,查閱了很多資料,有一些資料是一年前的,但是隨著瀏覽器版本的 變化,一些代碼已經老化,在這里一一總結和整理。這里只列舉了項目中用到的API,算是 對完成功能的一次梳理。

申請空間
為了進行數據的存儲,必須要向瀏覽器進行申請,如果是永久存儲還會向用戶進行詢問,只有 同意后才會繼續執行。

首先必須要聲明想要的權限。

復制代碼
代碼如下:

window.requestFileSystem = window.requestFileSystem || window.webkitRequestFileSystem; //文件系統請求標識
window.resolveLocalFileSystemURL = window.resolveLocalFileSystemURL || window.webkitResolveLocalFileSystemURL; //根據URL取得文件的讀取權限

得到系統的權限后就可以向瀏覽器申請空間

復制代碼
代碼如下:

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

回調函數

復制代碼
代碼如下:

function onInitFs(fs){
fs.root.getDirectory('catwrite_documents', {create: true}, function(dirEntry) {
console.log('You have just created the ' + dirEntry.name + ' directory.');
}, errorHandler);
}
//錯誤回調
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);
}

如果成功后悔調用OnInitFs回調函數,在里面用了getDirectory方法用來創建一個文件夾,這下面再說。

但是這是有個問題,這樣做的話每次加載頁面都會申請,這肯定不是我們想要的,我們要 的是在有數據的時候就可以讀取數據。

判斷是否申請過空間
所以我們需要讀取瀏覽器的數據,看看是否已有存儲。這就用到了另一個API:

復制代碼
代碼如下:

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

這個API可以查詢當前web的空間情況,如果成功的話就會調用successCallback回調函數 并把已用空間和全部空間作為參數傳入方法中。如果失敗則調去errorCallback。

復制代碼
代碼如下:

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

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

獲取文件入口
FileSystem使用了特殊的文件系統和沙盒模式,在電腦上或者其他web中是無法訪問沙盒中的文件的 ,只能用對應的格式去訪問。

在瀏覽器中輸入:

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

這樣可以訪問catcoder.com這個網站在本機永久數據,把persistent換成temporary則是讀取臨時空間。

然后我們就可以通過URL和對應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
);

下面就可以讀取本機存儲的數據了

復制代碼
代碼如下:

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("默認文件", "");
console.log("沒有文件!");
}else{
console.log("讀取到" + results.length + "個文件");
for(var i = 0; i < results.length; i++){
console.log(results[i].name);
getFileContentByName(fileEntry, results[i].name);
}
}
},errorHandler);
};
readEntries();
},errorHandler);

標簽:平涼 南平 山南 平頂山 黃石 陜西 黃石 公主嶺

巨人網絡通訊聲明:本文標題《基于HTML5 FileSystem API的使用介紹》,本文關鍵詞  基于,HTML5,FileSystem,API,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于HTML5 FileSystem API的使用介紹》相關的同類信息!
  • 本頁收集關于基于HTML5 FileSystem API的使用介紹的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 黑山县| 南川市| 军事| 仲巴县| 南陵县| 视频| 贵州省| 玛多县| 兴文县| 文山县| 肇源县| 林口县| 乐陵市| 灵寿县| 梅河口市| 雷波县| 菏泽市| 五指山市| 巴彦淖尔市| 锦州市| 义马市| 扶沟县| 秭归县| 萝北县| 天津市| 澎湖县| 通山县| 泊头市| 贺州市| 苏尼特右旗| 隆林| 天等县| 庆元县| 昭平县| 门头沟区| 厦门市| 东海县| 汪清县| 泸西县| 海宁市| 苏尼特右旗|