老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業(yè)提供網(wǎng)站建設(shè)、域名注冊、服務(wù)器等服務(wù)

怎么在HTML5項(xiàng)目中使用FileSystemAPI

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

“只有客戶發(fā)展了,才有我們的生存與發(fā)展!”這是創(chuàng)新互聯(lián)的服務(wù)宗旨!把網(wǎng)站當(dāng)作互聯(lián)網(wǎng)產(chǎn)品,產(chǎn)品思維更注重全局思維、需求分析和迭代思維,在網(wǎng)站建設(shè)中就是為了建設(shè)一個(gè)不僅審美在線,而且實(shí)用性極高的網(wǎng)站。創(chuàng)新互聯(lián)對(duì)成都做網(wǎng)站、成都網(wǎng)站制作、網(wǎng)站制作、網(wǎng)站開發(fā)、網(wǎng)頁設(shè)計(jì)、網(wǎng)站優(yōu)化、網(wǎng)絡(luò)推廣、探索永無止境。

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

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

在CatWrite項(xiàng)目中,運(yùn)用了HTML5的這個(gè)特性進(jìn)行數(shù)據(jù)的存儲(chǔ),很是方便,只是目前來說只有 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ì)向用戶進(jì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方法用來創(chuàng)建一個(gè)文件夾,這下面再說。

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

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

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


這個(gè)API可以查詢當(dāng)前web的空間情況,如果成功的話就會(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); 


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

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

在瀏覽器中輸入:

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

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

然后我們就可以通過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("沒有文件!"); 
            }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);

關(guān)于怎么在HTML5項(xiàng)目中使用FileSystem  API問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識(shí)。


分享文章:怎么在HTML5項(xiàng)目中使用FileSystemAPI
網(wǎng)站鏈接:http://www.xueling.net.cn/article/pjejho.html

其他資訊

在線咨詢
服務(wù)熱線
服務(wù)熱線:028-86922220
TOP
主站蜘蛛池模板: 韩国久久久久久 | 日日嗨av一区二区三区四区 | 两口子交换真实刺激高潮 | 亚洲制服丝袜欧美 | 夜夜高潮夜夜爽夜夜爱 | 亚洲午夜影视 | 欧美大胆a视频 | 亚洲成AⅤ人影院在线欢看 东北露脸熟妇XXXXX | 日本va欧美va欧美va精品 | 国产亚洲精品久久飘花 | 成年视频在线观看 | 国产性猛交粗暴力xxxx | 噜噜噜在线观看免费视频日本 | www.拔插拔插 | 精品一区二区三区四区 | 少妇水多多 | 人成午夜大片免费视频 | 国产一久久 | 69堂官网| 丰满人妻翻云覆雨呻吟视频 | 91新人在线观看 | 亚洲人成网在线播放 | 国产剧情久久久 | 无翼乌18禁全肉肉无遮挡彩色 | 成人性视频免费 | 深夜免费福利 | 免费岛国视频 | 麻豆自拍偷拍 | 日韩欧一区 | 国产一区二区三区在线观看网站 | 天天做天天爱天天综合网 | 日本一区免费在线 | a∨网站| 色噜噜狠狠一区二区三区果冻 | 无码人妻丰满熟妇精品区 | 久草在线小说 | 亚洲AV成人片色在线观看蜜桃 | 国产va免费精品观看精品老师 | 久久亚洲AV秘无码久久 | 欧美日韩一区不卡 | 成人国产 |