iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在HTML5项目中使用FileSystem API
  • 744
分享到

怎么在HTML5项目中使用FileSystem API

2023-06-09 21:06:54 744人浏览 独家记忆
摘要

怎么在HTML5项目中使用FileSystem  api?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。HTML5的强大之一就是允许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问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: 怎么在HTML5项目中使用FileSystem API

本文链接: https://www.lsjlt.com/news/257809.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在HTML5项目中使用FileSystem API
    怎么在HTML5项目中使用FileSystem  API?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。HTML5的强大之一就是允许web程序申请一些临时或者永久的...
    99+
    2023-06-09
  • 怎么在vue项目中使用百度地图API
    小编给大家分享一下怎么在vue项目中使用百度地图API,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!为什么要使用VueVue是一款友好的、多用途且高性能的Java...
    99+
    2023-06-14
  • 怎么在Vue项目中使用mock.js
    这篇文章主要讲解了“怎么在Vue项目中使用mock.js”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么在Vue项目中使用mock.js”吧!在Vue项目中使用mock.js开发工具选择:...
    99+
    2023-06-27
  • 怎么在React项目中使用Redux
    这篇文章主要介绍“怎么在React项目中使用Redux”,在日常操作中,相信很多人在怎么在React项目中使用Redux问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么在R...
    99+
    2022-10-18
  • ViewDragHelper怎么在Android项目中使用
    本篇文章为大家展示了 ViewDragHelper怎么在Android项目中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。ViewDragHelper是support.v4下提供的用于处理拖拽滑...
    99+
    2023-05-30
    android viewdraghelper
  • ContentProvider怎么在Android项目中使用
    ContentProvider怎么在Android项目中使用?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、概念及说明ContentProvider定义:内容提供者是一个An...
    99+
    2023-05-31
    android contentprovider roi
  • listfragment怎么在Android项目中使用
    本篇文章给大家分享的是有关listfragment怎么在Android项目中使用,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、fragment简介我对fragment的理解...
    99+
    2023-05-31
    android listfragment roi
  • Newtonsoft.Json怎么在c#项目中使用
    本篇文章为大家展示了 Newtonsoft.Json怎么在c#项目中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。1 实体类的 Json 序列化和反序列化我们以如下的 Person 类举例,其中...
    99+
    2023-06-06
  • System.Windows.Interactivity怎么在c# 项目中使用
    这篇文章给大家介绍System.Windows.Interactivity怎么在c# 项目中使用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1 引入命名空间  通过在代码中引入System.Windows.Inter...
    99+
    2023-06-06
  • 怎么在vue3.0项目中使用element
    这篇文章给大家介绍怎么在vue3.0项目中使用element,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。vue是什么软件Vue是一套用于构建用户界面的渐进式JavaScript框架,Vue与其它大型框架的区别是,使用...
    99+
    2023-06-06
  • web worker在项目中怎么使用
    这篇文章主要介绍“web worker在项目中怎么使用”,在日常操作中,相信很多人在web worker在项目中怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”web wo...
    99+
    2023-07-02
  • HttpURLConnection怎么在Java项目中使用
    这篇文章将为大家详细讲解有关HttpURLConnection怎么在Java项目中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。包括使用HttpURLConnection执行get/po...
    99+
    2023-05-30
    java httpurlconnection
  • 怎么在uniapp项目中使用mqtt
    这篇文章将为大家详细讲解有关怎么在uniapp项目中使用mqtt,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、uniapp插件市场的参考插件  https://ext.dcloud.net.cn/pl...
    99+
    2023-06-15
  • 怎么在PHP项目中使用Swoole
    这篇“怎么在PHP项目中使用Swoole”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“怎么在PHP项目中使用Swoole”文...
    99+
    2023-07-05
  • forEach在项目中怎么用
    这篇文章给大家分享的是有关forEach在项目中怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 forEach会改变原始数组  被forEach循环的数组不能够...
    99+
    2022-10-19
  • Hutool库怎么在Java项目中使用
    本文章向大家介绍Hutool库怎么在Java项目中使用的基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。简介Hutool是一个小而全的Java工具类库,通过静态方法封装,降低相关API的学习成本,提高工作效率,使J...
    99+
    2023-06-06
  • 怎么在uni-app项目中使用scss
    这期内容当中小编将会给大家带来有关怎么在uni-app项目中使用scss,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。上述就是小编为大家分享的怎么在uni-app项目中使用scss了,如果刚好有类似的疑惑...
    99+
    2023-06-08
  • atomic怎么在c++11项目中使用
    这期内容当中小编将会给大家带来有关atomic怎么在c++11项目中使用,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。std::atomic_flag  std::atomic_flag是一个原子的布尔类...
    99+
    2023-06-06
  • Calendar类怎么在java项目中使用
    Calendar类怎么在java项目中使用?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。java中的Calendar在开发中经常被忽略,这篇博客总结一下这个类,...
    99+
    2023-05-31
    java calendar ava
  • Lamar怎么在ASP.Net Core项目中使用
    这篇文章将为大家详细讲解有关Lamar怎么在ASP.Net Core项目中使用,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。为什么要用 Lamar 实现依赖注入要说 .NET 世界最早的依赖...
    99+
    2023-06-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作