react native 清除缓存
2019-04-22 本文已影响0人
路遇惊喜
1、安装react-native-http-cache
npm install react-native-http-cache --save
2、Linking Libraries
react-native link react-native-http-cache
执行这个命令之后,Android和iOS项目都会把库链接进去。
data:image/s3,"s3://crabby-images/3d1b0/3d1b026677440b9ab25c1901d452bcb3dc1652bf" alt=""
(PS: 如果该命令添加失败的话,需要自己在Xcode或者Android Studio 手动添加。)
3、分别配置Android
平台和iOS
平台
我也是按照github的文档配置的。
3.1 Android
把项目里面的android目录拖进Android Studio
3.1.1、修改MainApplication.java
文件
data:image/s3,"s3://crabby-images/8716f/8716f3ab5c0eb36412dbbce1963e85938e4ce7d1" alt=""
3.1.2、Android 修改 HttpCacheModule.java
文件
(目录为node_modules>react-native-http-cache>android>src>main>java>cn>reactnative>httpcache>HttpCacheModule.java)
//将69改成:
FileCache cache1 = ImagePipelineFactory.getInstance().getMainFileCache();
/将80行改成:
FileCache cache2 = ImagePipelineFactory.getInstance().getSmallImageFileCache();
如果不修改以上2个方法,会显示如下报错:
data:image/s3,"s3://crabby-images/8a912/8a9125f3530446e4580c91c7e759534d9752bcc5" alt=""
3.2、iOS
把项目里面的ios目录拖进Xcode
data:image/s3,"s3://crabby-images/15805/15805977e039e55c5b23ede1f6344931d65dc317" alt=""
4、在react native 项目使用react-native-http-cache
import * as CacheManager from 'react-native-http-cache';
我把CacheManager
打印了一下,可以看到它有这些方法:
data:image/s3,"s3://crabby-images/c2d18/c2d18e8924ae970a1d8434168dd2fbd36894dfd4" alt=""
以下方法返回的是一个 promise 对象
方法 | 说明 |
---|---|
CacheManager.clearCache() | 清除缓存 |
CacheManager.clearHttpCache() | 清除网络缓存 |
CacheManager.clearImageCache() | 清除图片缓存 |
CacheManager.getCacheSize() | 返回网络缓存大小和图片缓存大小 |
CacheManager.getImageCacheSize() | 获取图片缓存 |
CacheManager.getHttpCacheSize() | 获取网络缓存 |
//获取缓存
getCache(){
CacheManager.getCacheSize().then(res=>{
let cacheSize = Math.round((res / 1024 / 1024) * 100) / 100 + 'M';
this.setState({
cacheSize
})
},err=>{
console.log(err)
})
}
//清除缓存
clearCache(){
CacheManager.clearCache();
this.setState({
cacheSize: '0M'
})
}
经测试,清楚缓存之后,还是会有0.15M 。为了界面好看点,我在上面的代码中直接设置清除缓存后为0M了。
data:image/s3,"s3://crabby-images/a7eab/a7eabbb65d09dfb2770f6c8c1a8ef08dbf46a47d" alt=""