react-native-fs文件创建、查看、上传、下载

一、安装依赖
  1. install
npm install react-native-fs --save
  1. link
react-native link react-native-fs

如果link失败,或者link之后仍旧不能import,则考虑手动link,详情查看官网教程,传送门(温馨提示:新install依赖之后,记得重启一下app——react-native run-ios //Android react-native run-android

二、使用例子
1. 获得文件夹路径
import RNFS from 'react-native-fs';

//打印出常用路径
printPaths = () => {
  console.log('MainBundlePath=' + RNFS.MainBundlePath)
  console.log('CachesDirectoryPath=' + RNFS.CachesDirectoryPath)
  console.log('DocumentDirectoryPath=' + RNFS.DocumentDirectoryPath)
  console.log('TemporaryDirectoryPath=' + RNFS.TemporaryDirectoryPath)
  console.log('LibraryDirectoryPath=' + RNFS.LibraryDirectoryPath)
  console.log('ExternalDirectoryPath=' + RNFS.ExternalDirectoryPath)
  console.log('ExternalStorageDirectoryPath=' + RNFS.ExternalStorageDirectoryPath)

  //打印日志---ios
  // MainBundlePath=/var/containers/Bundle/Application/9115F4F8-B2F6-4594-B2FC-9FF173946670/DvaStarter.app
  // CachesDirectoryPath=/var/mobile/Containers/Data/Application/558EF9E2-31DA-46FF-925F-160BB4D1EF35/Library/Caches
  // DocumentDirectoryPath=/var/mobile/Containers/Data/Application/558EF9E2-31DA-46FF-925F-160BB4D1EF35/Documents
  // TemporaryDirectoryPath=/private/var/mobile/Containers/Data/Application/558EF9E2-31DA-46FF-925F-160BB4D1EF35/tmp/
  // LibraryDirectoryPath=/var/mobile/Containers/Data/Application/558EF9E2-31DA-46FF-925F-160BB4D1EF35/Library
  // ExternalDirectoryPath=null
  // ExternalStorageDirectoryPath=null
}

这里可以简单了解一下ios的沙盒模型。
1、Documents 目录:您应该将所有的应用程序数据文件写入到这个目录下。这个目录用于存储用户数据。该路径可通过配置实现iTunes共享文件。可被iTunes备份。

2、AppName.app 目录:这是应用程序的程序包目录,包含应用程序的本身。由于应用程序必须经过签名,所以您在运行时不能对这个目录中的内容进行修改,否则可能会使应用程序无法启动。

3、Library 目录:这个目录下有两个子目录:
3.1 Preferences 目录:包含应用程序的偏好设置文件。您不应该直接创建偏好设置文件,而是应该使用NSUserDefaults类来取得和设置应用程序的偏好.
3.2 Caches 目录:用于存放应用程序专用的支持文件,保存应用程序再次启动过程中需要的信息。
可创建子文件夹。可以用来放置您希望被备份但不希望被用户看到的数据。该路径下的文件夹,除Caches以外,都会被iTunes备份。

4、tmp 目录:这个目录用于存放临时文件,保存应用程序再次启动过程中不需要的信息。该路径下的文件不会被iTunes备份。

2. 文件下载RNFS.downloadFile

react-native-fs提供了下载文件的方法。

downloadFile(options: DownloadFileOptions): { jobId: number, promise: Promise<DownloadResult> }

方法解析:
需要一个参数options,格式如下:

type DownloadFileOptions = {
  fromUrl: string;          //下载的地址源(即下载链接)
  toFile: string;           // 本地的存储路径(路径包括文件名)
  headers?: Headers;        // 需要传递给服务器的报头(根据服务器的需要传,一般不用)
  background?: boolean;     // 是否允许在后台下载(仅适用于iOS)
  discretionary?: boolean;  // 是否允许手机操作系统控制下载  (仅适用于iOS)
  progressDivider?: number;//进度回调函数调用的频率(假设设置为5,则每完成5%,就会回调一次progress函数。默认为0,回调频率很高,会影响性能)
  begin?: (res: DownloadBeginCallbackResult) => void;//开始下载时的回调函数
  progress?: (res: DownloadProgressCallbackResult) => void;//下载过程中的回调函数(与属性progressDivider搭配使用)
  resumable?: () => void;    // 是否允许继续继续下载(仅适用于iOS) 
  connectionTimeout?: number // 连接超时时间(仅适用于Android)
  readTimeout?: number       // 读取数据超时时间(适用于Android and iOS)
};

该方法返回一个对象,属性jobId为任务id,为number类型,用于暂停下载和继续下载。属性promise是一个Promise对象,可用来判断下载是否完成,进而执行下载完成后的一些操作。

//设置下载参数
const options = {
  fromUrl: videoUrl,
  toFile: toFile,
  background: true,
  progressDivider: 5,
  begin: (res) => {
    //开始下载时回调
    console.log('begin', res);
  },
  progress: (res) => {
    //下载过程中回调,根据options中设置progressDivider:5,则在完成5%,10%,15%,...,100%时分别回调一次,共回调20次。
    console.log('progress', res)
  }
}
const ret = RNFS.downloadFile(options);//调用downloadFile开始下载
console.log(ret.jobId); //打印一下看看jobId
ret.promise.then(res => {
  //下载完成时执行
  console.log(res)
}
.catch(err => {
  //下载出错时执行
  console.log(err)
}


未完待续。。。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,214评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,307评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,543评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,221评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,224评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,007评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,313评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,956评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,441评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,925评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,018评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,685评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,234评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,240评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,464评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,467评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,762评论 2 345

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,499评论 25 707
  • 英语太烂,菜鸟水平,如有不妥之处,请各位大神指正 工作原理 React Native应用程序由JavaScript...
    Juice_gg阅读 3,724评论 0 4
  • 搜罗自各大网站,新闻媒体端 一直在想自己以后头发的样子
    i爱自然阅读 250评论 0 0
  • 年少时读《小王子》,对星际旅行一节印象颇深。他曾来到一个酒鬼的星球: “你在干什么?”小王子问酒鬼,这个酒鬼默默地...
    魏谜底阅读 10,517评论 6 55
  • 我是昨晚在单位食堂吃完晚饭在小区的小路边见到它的。它一身黄白相间的皮毛,身形娇小,独自一人蹲在路边张望、巡视,看见...
    若水Dewlight阅读 344评论 0 3