<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        基于HTML5FileSystemAPI的使用介紹_html5教程技巧

        來源:懂視網 責編:小采 時間:2020-11-27 15:18:03
        文檔

        基于HTML5FileSystemAPI的使用介紹_html5教程技巧

        基于HTML5FileSystemAPI的使用介紹_html5教程技巧:HTML5的強大之一就是允許web程序申請一些臨時或者永久的空間(Quota)在這里可以進行 數據的存儲甚至文件的操作。 FileSystem提供了文件夾和文件的創建、移動、刪除等操作,大大方便了數據的本地處理, 而且所有的數據都是在沙盒(sandboxed)中,不
        推薦度:
        導讀基于HTML5FileSystemAPI的使用介紹_html5教程技巧:HTML5的強大之一就是允許web程序申請一些臨時或者永久的空間(Quota)在這里可以進行 數據的存儲甚至文件的操作。 FileSystem提供了文件夾和文件的創建、移動、刪除等操作,大大方便了數據的本地處理, 而且所有的數據都是在沙盒(sandboxed)中,不

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


        我們可以通過判斷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);

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        基于HTML5FileSystemAPI的使用介紹_html5教程技巧

        基于HTML5FileSystemAPI的使用介紹_html5教程技巧:HTML5的強大之一就是允許web程序申請一些臨時或者永久的空間(Quota)在這里可以進行 數據的存儲甚至文件的操作。 FileSystem提供了文件夾和文件的創建、移動、刪除等操作,大大方便了數據的本地處理, 而且所有的數據都是在沙盒(sandboxed)中,不
        推薦度:
        標簽: API html5 system
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 日韩免费一区二区三区在线| 亚洲天堂中文资源| 亚洲高清毛片一区二区| aa级一级天堂片免费观看| 亚洲综合视频在线观看| av无码久久久久不卡免费网站| 亚洲综合无码一区二区三区| 91香蕉国产线观看免费全集| 亚洲乱码中文字幕小综合| 成年人免费网站在线观看| 色婷婷亚洲一区二区三区| 亚洲国产天堂久久综合| a级毛片100部免费观看| 亚洲午夜在线电影| 成人免费视频小说| 日韩精品免费一线在线观看| 国产亚洲精品看片在线观看 | 亚洲欧洲日产国码久在线观看| A级毛片高清免费视频在线播放| 亚洲电影免费在线观看| 日韩国产免费一区二区三区| 亚洲欧洲无卡二区视頻| 久久夜色精品国产亚洲av| 99久久精品国产免费| 亚洲色中文字幕在线播放| 亚洲男人av香蕉爽爽爽爽| 久久国产乱子伦精品免费看| 亚洲国产区男人本色在线观看| 免费又黄又爽又猛的毛片| 免费女人高潮流视频在线观看| 亚洲中文字幕一二三四区苍井空 | 亚洲午夜在线播放| 亚洲人妻av伦理| 最近2019中文字幕免费大全5| 亚洲国产精品无码久久九九大片| 精品亚洲视频在线观看 | 亚洲国产另类久久久精品小说 | 亚洲乱理伦片在线观看中字| 国产亚洲精品激情都市| 久久国内免费视频| 两个人的视频www免费|