Expo大作战(三十八)--expo sdk api之 FileSystem(文件操作系统)

news/2024/7/7 21:43:55

 

简要:本系列文章讲会对expo进行全面的介绍,本人从2017年6月份接触expo以来,对expo的研究断断续续,一路走来将近10个月,废话不多说,接下来你看到内容,讲全部来与官网

我猜去全部机翻+个人修改补充+demo测试的形式,对expo进行一次大补血!欢迎加入expo兴趣学习交流群:597732981

【之前我写过一些列关于expo和rn入门配置的东i西,大家可以点击这里查看:从零学习rn开发】

相关文章:

Expo大作战(一)--什么是expo,如何安装expo clinet和xde,xde如何使用

Expo大作战(二)--expo的生命周期,expo社区交流方式,expo学习必备资源,开发使用expo时关注的一些问题

Expo大作战(三)--针对已经开发过react native项目开发人员有针对性的介绍了expo,expo的局限性,开发时项目选型注意点等

Expo大作战(四)--快速用expo构建一个app,expo中的关键术语

Expo大作战(五)--expo中app.json 文件的配置信息

Expo大作战(六)--expo开发模式,expo中exp命令行工具,expo中如何查看日志log,expo中的调试方式

Expo大作战(七)--expo如何使用Genymotion模拟器

Expo大作战(八)--expo中的publish以及expo中的link,对link这块东西没有详细看,大家可以来和我交流

更多>>

写在二十三章以后的话,之前的翻译,不管如何,好与不好,终究是告一段落,也把expo基础理论的东西又深入的理解了一遍,后续expo大作战系列将主要介绍expo sdk的api。


文件系统

提供对本地存储在设备上的文件系统的访问。每个Expo应用程序都有独立的文件系统,无法访问其他Expo应用程序的文件系统。该API将file:// URI指向设备上的本地文件以识别文件。每个应用程序只能读取和写入以下目录下的位置:

Expo.FileSystem.documentDirectory

file:// URI指向将存储此应用程序的用户文档的目录。存储在这里的文件将保留直到被应用程序明确删除。尾随/。示例用途用于用户保存的文件,以便他们再次看到。

Expo.FileSystem.cacheDirectory

file:// URI指向存储此应用程序使用的临时文件的目录。存储空间不足时,此处存储的文件可能会被系统自动删除。示例用途用于应用程序只需要一次性使用的下载或生成的文件。

因此,例如,应用程序用户文档目录中“myDirectory”下名为“myFile”的文件的URI将为Expo.FileSystem.documentDirectory +'myDirectory / myFile'。

创建文件的Expo API通常在这些目录中运行。这包括音频录制,相机照片,ImagePicker结果,SQLite数据库和takeSnapShotAsync()结果。这允许它们与FileSystem API一起使用。

某些FileSystem功能可以读取(但不写入)其他位置。目前Expo.FileSystem.getInfoAsync()和Expo.FileSystem.copyAsync()能够从React Native中的CameraRoll.getPhotos()返回的URI中读取。

Expo.FileSystem.getInfoAsync(fileUri,options)
获取关于文件或目录的元数据信息。

参数
fileUri(string) - file://指向文件或目录的URI,或CameraRoll.getPhotos()返回的URI。

options(object) - 选项图:

  • md5(boolean) - 是否返回文件的MD5哈希值。默认为false。
  • size(boolean) - 如果在来自CameraRoll.getPhotos()的源文件上操作,是否包含文件的大小(例如,如果文件存储在iCloud中,则跳过这可以防止下载文件)。大小总是返回file://locations。

返回
如果此URI不存在项目,则返回{exists:false,isDirectory:false}。否则返回包含以下字段的对象:

  • exists(boolean) - true。
  • isDirectory(boolean) - 如果这是一个目录,则为true;如果是文件,则为false
  • modificationTime (number)  - 自纪元以来以秒为单位表示的文件的最后修改时间。
  • size (number)  - 文件的大小(以字节为单位)。如果在来自CameraRoll.getPhotos()的源上进行操作,则仅在尺寸选项非常真实时才存在。
  • uri (string)  - 指向文件的file:// URI。这与fileUri输入参数相同。
  • md5 (string)  - 如果md5选项真的存在,则显示。包含文件的MD5哈希。

Expo.FileSystem.readAsStringAsync(fileURI)
以字符串形式读取文件的全部内容。

参数
fileUri(string) - 文件://文件或目录的URI。

返回
包含文件全部内容的字符串。

Expo.FileSystem.writeAsStringAsync(fileUri,contents)
以字符串形式写入文件的全部内容。

参数
fileUri(string) - file://文件或目录的URI。

contents(string) - 用来替换文件内容的字符串。

Expo.FileSystem.deleteAsync(fileUri,options)
删除文件或目录。如果URI指向一个目录,则该目录及其所有内容将被递归删除。

参数
fileUri(string) - file://文件或目录的URI。

options(object) - 选项图:

  • idempotent(boolean) - 如果为true,则在此URI没有文件或目录时不要抛出错误。默认为false。

Expo.FileSystem.moveAsync(options)
将文件或目录移动到新位置。

参数
options(object) - 选项图:

  • from (string)  - file:// URI到原始位置的文件或目录。
  • to (string)  - file:// URI指向文件或目录,该文件或目录应该是其新位置。

Expo.FileSystem.copyAsync(options)
创建文件或目录的副本。目录以其所有内容递归复制。

参数
options(object) - 选项图:

from(string) - file:// URI复制到要复制的文件或目录,或由CameraRoll.getPhotos()返回的URI。

to(string) - 要创建的新副本的file:// URI。

Expo.FileSystem.makeDirectoryAsync(fileUri,options)
创建一个新的空目录。

参数
fileUri(string) - file://创建新目录的URI。

options(object) - 选项图:

  • intermediates(boolean) - 如果为true,则在fileUri上创建目录时创建任何不存在的父目录。如果为false,则在任何中间父目录不存在时引发错误。默认为false。

Expo.FileSystem.readDirectoryAsync(fileURI)
枚举目录的内容。

参数
fileUri(string) - file://目录的URI。

返回
一串字符串,每个字符串都包含文件或目录名称

Expo.FileSystem.downloadAsync(uri,fileUri,options)
将远程URI处的内容下载到应用程序文件系统中的文件中。

FileSystem.downloadAsync(
  'http://techslides.com/demos/sample-videos/small.mp4',
  FileSystem.documentDirectory + 'small.mp4'
)
  .then(({ uri }) => {
    console.log('Finished downloading to ', uri);
  })
  .catch(error => {
    console.error(error);
  });

参数
url(string) - 要从其下载的远程URI。

fileUri(string) - 要下载到的文件的本地URI。如果此URI没有文件,则会创建一个新文件。如果这个URI有一个文件,它的内容将被替换。

options(object) - 选项图:

  • md5(boolean) - 如果为true,则在返回的对象中包含文件的MD5哈希。默认为false。为方便起见,因为通常在下载后立即检查文件的完整性。

返回
返回包含以下字段的对象:

uri(string) - 指向文件的file:// URI。这与fileUri输入参数相同。

status (number)  - 下载网络请求的HTTP状态码。

headers (object)  - 包含所有HTTP标头字段及其下载网络请求值的对象。对象的键和值分别是标题名称和值。

md5 (string) - 如果md5选项真的存在,则显示。包含文件的MD5哈希。

Expo.FileSystem.createDownloadResumable(uri,fileUri,options,callback,resumeData)
创建一个DownloadResumable对象,它可以启动,暂停和恢复将远程URI下载的内容下载到应用文件系统中的文件。请注意:您需要在DownloadResumable实例上调用downloadAsync()以启动下载。 DownloadResumable对象具有提供下载进度更新的回调。通过使用AsyncStorage存储DownloadResumable.savable()对象以供日后检索,可以跨应用程序重新启动恢复下载。可保存对象包含在重新启动应用程序后初始化新的DownloadResumable对象以恢复下载所需的参数。

参数
url(string) - 要从其下载的远程URI。

fileUri(string) - 要下载到的文件的本地URI。如果此URI没有文件,则会创建一个新文件。如果这个URI有一个文件,它的内容将被替换。

options(object) - 选项图:

  • md5(boolean) - 如果为true,则在返回的对象中包含文件的MD5哈希。默认为false。为方便起见,因为通常在下载后立即检查文件的完整性。
  • headers (object)  - 包含请求所需的任何附加HTTP头字段的对象。对象的键和值分别是标题名称和值。

callback(function) - 在每次写入数据时调用此函数以更新下载进度。传递以下字段的对象:

  • totalBytesWritten(number) - 下载操作写入的总字节数。
  • totalBytesExpectedToWrite(number) - 预计由下载操作写入的字节总数。
  • resumeData(string) - 允许api恢复暂停下载的字符串。这在下载暂停时自动设置在DownloadResumable对象上。初始化新的DownloadResumable时,它应该为空。

Expo.FileSystem.DownloadResumable.downloadAsync()
将远程URI处的内容下载到应用程序文件系统中的文件中。

返回
返回包含以下字段的对象:

  • uri(string) - 指向文件的file:// URI。这与fileUri输入参数相同。
  • status (number) - 下载网络请求的HTTP状态码。
  • headers (object)  - 包含所有HTTP标头字段及其下载网络请求值的对象。对象的键和值分别是标题名称和值。
  • md5(string) - 如果md5选项真的存在,则显示。包含文件的MD5哈希。

Expo.FileSystem.DownloadResumable.pauseAsync()
暂停当前​​的下载操作。在成功暂停操作后,resumeData被添加到DownloadResumable对象中。返回可以使用AsyncStorage进行保存以供将来检索的对象(与调用Expo.FileSystem.DownloadResumable.savable()时返回的对象相同。请参见下面的示例。

返回
返回包含以下字段的对象:

  • url(string) - 要从其下载的远程URI。
  • fileUri(string) - 要下载到的文件的本地URI。如果此URI没有文件,则会创建一个新文件。如果这个URI有一个文件,它的内容将被替换。
  • options(object) - 选项图:
  • md5(boolean) - 如果为true,则在返回的对象中包含文件的MD5哈希。默认为false。为方便起见,因为通常在下载后立即检查文件的完整性。
  • resumeData(string) - 允许API恢复暂停下载的字符串。

Expo.FileSystem.DownloadResumable.resumeAsync()
恢复暂停的下载操作。

返回
返回包含以下字段的对象:

  • uri(string) - 指向文件的file:// URI。这与fileUri输入参数相同。
  • status (number) - 下载网络请求的HTTP状态码。
  • headers (object)  - 包含所有HTTP标头字段及其下载网络请求值的对象。对象的键和值分别是标题名称和值。
  • md5(string) - 如果md5选项真的存在,则显示。包含文件的MD5哈希。

Expo.FileSystem.DownloadResumable.savable()
返回可以与AsyncStorage一起保存的对象以供将来检索。

返回
返回包含以下字段的对象:

url(string) - 要从其下载的远程URI。

fileUri(string) - 要下载到的文件的本地URI。如果此URI没有文件,则会创建一个新文件。如果这个URI有一个文件,它的内容将被替换。

options(object) - 选项图:

  • md5(boolean) - 如果为true,则在返回的对象中包含文件的MD5哈希。默认为false。为方便起见,因为通常在下载后立即检查文件的完整性。
  • resumeData(string) - 允许api恢复暂停下载的字符串。

const callback = downloadProgress => {
  const progress =
    downloadProgress.totalBytesWritten /
    downloadProgress.totalBytesExpectedToWrite;
  this.setState({
    downloadProgress: progress,
  });
};

const downloadResumable = FileSystem.createDownloadResumable(
  'http://techslides.com/demos/sample-videos/small.mp4',
  FileSystem.documentDirectory + 'small.mp4',
  {},
  callback
);

try {
  const { uri } = await downloadResumable.downloadAsync();
  console.log('Finished downloading to ', uri);
} catch (e) {
  console.error(e);
}

try {
  await downloadResumable.pauseAsync();
  console.log('Paused download operation, saving for future retrieval');
  AsyncStorage.setItem(
    'pausedDownload',
    JSON.stringify(downloadResumable.savable())
  );
} catch (e) {
  console.error(e);
}

try {
  const { uri } = await downloadResumable.resumeAsync();
  console.log('Finished downloading to ', uri);
} catch (e) {
  console.error(e);
}

//To resume a download across app restarts, assuming the the DownloadResumable.savable() object was stored:
const downloadSnapshotJson = await AsyncStorage.getItem('pausedDownload');
const downloadSnapshot = JSON.parse(downloadJson);
const downloadResumable = new FileSystem.DownloadResumable(
  downloadSnapshot.url,
  downloadSnapshot.fileUri,
  downloadSnapshot.options,
  callback,
  downloadSnapshot.resumeData
);

try {
  const { uri } = await downloadResumable.resumeAsync();
  console.log('Finished downloading to ', uri);
} catch (e) {
  console.error(e);
}

下一张继续介绍,这一篇主要介绍了:expo sdk api之 FileSystem(文件操作系统)欢迎大家关注我的微信公众号,这篇文章是否被大家认可,我的衡量标准就是公众号粉丝增长人数。欢迎大家转载,但必须保留本人博客链接!

 


http://www.niftyadmin.cn/n/3060827.html

相关文章

假冒谷歌爬虫成为第三大 DDoS 攻击工具

在安全牛之前发布的文章《Prolexic发布2014年第一季度全球DDoS攻击报告》中,我们了解到采用“反射放大”技术发起的攻击流量比上一季度增加了39%,同时攻击者也在不断发掘利用其他一些互联网基础服务来发动DDoS攻击,例如今年3月安全公司Sucuri…

denry相关的各种hash函数

d_hash(dentry,hash) 为散列函数 , 它将 dentry 地址和 hash 值相组合, 映射到 dentry_hashtable 表中 , 返回相应的散列链 ;在底层文件系统的i_op中也有一个同名的d_hash函数,这个函数仅用来计算目录项对应的散列值;d_rehash(dentry) 将 dentry 加入散列…

docker环境部署postgres版本nacos

1、docker安装postgres 执行命令:docker pull postgres 拉取最新版postgres 2、查看postgres镜像是否安装成功: docker imags(查看镜像),可以看到已经拉取到了最新版本 的postgres镜像 3、编辑一个docker-compose.yml文件,账号是postgres&a…

如何勾引马云、马化腾花钱买你公司?

在互联网领域创业,有句调侃要么被BAT收购,要么老死众生。把公司卖给BAT,尤其是的当下拼命收购的阿里腾讯,几乎成了很多互联网创业公司的命数。那么,对那些渴望被投资或被买走的创业者,究竟怎样才能引起马云…

dentry数据组织与相关操作

Linux用数据结构dentry来描述fs中与某个文件索引节点相链接的一个目录项(可以是文件,也可以是目录)。   每个dentry对象都属于下列几种状态之一:   (1)未使用(unused)状态:该dentry对象的引用计数d_cou…

mysql性能瓶颈分析、性能指标、指标搜集方法与性能分析调优工具【转】

本文主要讲解mysql的性能瓶颈分析、性能指标、性能指标信息的搜集工具与方法、分析调优工具的使用。 文章尚未完成。 性能瓶颈: 慢、写速度比读速度慢很多 主要的性能指标: 访问频度, 并发连接量, 缓存命中率, index…

断开网线黑客也能盗走你的数据

一旦电脑感染病毒或者木马,一般人首先想到“先断开网线”,避免机密数据通过上网通道被窃走。不过根据安全专家的研究,即使是断开网线的“PC孤岛”,黑客也能利用电磁波等技术,“隔空”盗走数据。 以色列Ben-Gurion大学的…

freqz()

实函数的傅里叶变换的幅度谱是偶函数,其相位谱为奇函数。这一特性在信号分析中得到广泛应用。 离散系统频响特性的函数freqz()[H,W ] freqz(b,a,n)返回量H则包含了离散系统频响在 0~pi范围内N个频率等分点…