91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在HTML5項目中使用FileSystem API

發布時間:2021-03-24 15:05:16 來源:億速云 閱讀:254 作者:Leah 欄目:web開發

怎么在HTML5項目中使用FileSystem  API?針對這個問題,這篇文章詳細介紹了相對應的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。

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問題的解答就分享到這里了,希望以上內容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關注億速云行業資訊頻道了解更多相關知識。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

潞城市| 沙湾县| 肥东县| 涿鹿县| 杭州市| 翼城县| 平利县| 荣昌县| 富锦市| 万全县| 绵竹市| 濉溪县| 宁强县| 佳木斯市| 盈江县| 沛县| 萍乡市| 宜宾县| 乌什县| 彰武县| 勃利县| 姜堰市| 句容市| 平湖市| 柳河县| 鄂托克前旗| 哈尔滨市| 长岛县| 沾化县| 濮阳县| 台山市| 依安县| 浮山县| 红原县| 临沭县| 扎鲁特旗| 佛教| 桑植县| 佛学| 余庆县| 沿河|