• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題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關(guān)鍵字專題關(guān)鍵字專題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
    當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

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

    來源:懂視網(wǎng) 責(zé)編:小采 時間:2020-11-27 15:18:03
    文檔

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

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

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

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

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

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

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

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

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

    得到系統(tǒng)的權(quán)限后就可以向瀏覽器申請空間

    代碼如下:
    window.requestFileSystem(window.PERSISTENT, //persistent(永久) or temporary(臨時)
    1024*1024, //1M
    onInitFs, //成功后的回調(diào)函數(shù)
    errorHandler); //錯誤后的回調(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);
    }
    //錯誤回調(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方法用來創(chuàng)建一個文件夾,這下面再說。

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

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

    代碼如下:
    void queryUsageAndQuota(
    in DOMString url,
    in EntryCallback successCallback,
    in optional ErrorCallback errorCallback
    );

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

    代碼如下:
    window.webkitStorageInfo.queryUsageAndQuota(webkitStorageInfo.PERSISTENT,
    function(used, remaining){
    if(remaining == ""){
    console.log("未申請空間。");
    }else{
    console.log("已使用空間"+used);
    console.log("全部空間"+remaining);
    }
    },
    errorHandler);


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

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

    在瀏覽器中輸入:

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

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

    然后我們就可以通過URL和對應(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ī)存儲的數(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("沒有文件!");
    }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);

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

    文檔

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

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 人妻无码精品久久亚瑟影视| 日韩精品一区二三区中文| 青青青青久久精品国产| 在线精品自拍无码| 国产精品麻豆入口| 国产精品视频免费观看| 老司机67194精品线观看| 日韩人妻无码精品无码中文字幕 | 久久无码精品一区二区三区| 四虎国产精品免费久久5151| 久久狠狠高潮亚洲精品| 宅男宅女精品国产AV天堂| 久久se这里只有精品| 国产精品igao视频| 999国产精品视频| 麻豆精品不卡国产免费看| HEYZO无码综合国产精品227| 无码国内精品久久人妻蜜桃| 欧美日韩国产中文精品字幕自在自线 | 国产手机在线精品| 久久精品国产亚洲精品2020| 无翼乌无遮挡全彩老师挤奶爱爱帝国综合社区精品 | 日韩精品成人亚洲专区| 国产精品哟女在线观看| 欧美激情精品久久久久| 国产精品三级在线| 国产精品宾馆在线精品酒店| 国内精品久久久久久久久| 日韩精品极品视频在线观看免费 | 亚洲第一极品精品无码久久| 一本久久a久久精品综合香蕉| 亚洲A∨精品一区二区三区| 久久伊人精品青青草原日本| 精品亚洲视频在线观看| 久久国产热这里只有精品| 久久精品视屏| 合区精品中文字幕| 亚洲色精品88色婷婷七月丁香| 亚洲色精品88色婷婷七月丁香 | 精品无码人妻一区二区免费蜜桃| 亚洲精品二区国产综合野狼 |