uniapp中在app中清除缓存功能

1.计算缓存大小

javascript 复制代码
	//计算缓存大小
			getStorageSize() {
				let that = this;
				let fileSizeString = "";
				let isFlag = arrIndex(this.menuList, 'key', 'my-ql')
				plus.cache.calculate(function(size) {
					let sizeCache = parseInt(size);
					if (sizeCache == 0) {
						fileSizeString = "0B";
					} else if (sizeCache < 1024) {
						fileSizeString = sizeCache + "B";
					} else if (sizeCache < 1048576) {
						fileSizeString = (sizeCache / 1024).toFixed(2) + "K";
					} else if (sizeCache < 1073741824) {
						fileSizeString = (sizeCache / 1048576).toFixed(2) + "M";
					} else {
						fileSizeString = (sizeCache / 1073741824).toFixed(2) + "G";
					}
					//本地缓存赋值
					that.menuList[isFlag[0]][isFlag[1]].text = fileSizeString
				});
			},

2.清除缓存

javascript 复制代码
// 清理缓存
			clearStorageAll() {
				let that = this;
				let os = plus.os.name;
				if (os == 'Android') {
					let main = plus.android.runtimeMainActivity();
					let sdRoot = main.getCacheDir();
					let files = plus.android.invoke(sdRoot, "listFiles");
					let len = files.length;
					for (let i = 0; i < len; i++) {
						let filePath = '' + files[i]; // 没有找到合适的方法获取路径,这样写可以转成文件路径
						plus.io.resolveLocalFileSystemURL(filePath, function(entry) {
							if (entry.isDirectory) {
								entry.removeRecursively(function(entry) { //递归删除其下的所有文件及子目录
									uni.showToast({
										title: '缓存清理完成',
										duration: 2000
									});
									that.getStorageSize(); // 重新计算缓存
								}, function(e) {
									console.log(e.message)
								});
							} else {
								entry.remove();
							}
						}, function(e) {
							console.log('文件路径读取失败')
						});
					}
				} else { // ios
					plus.cache.clear(function() {
						uni.showToast({
							title: '缓存清理完成',
							duration: 2000
						});
						that.getStorageSize();
					});
				}
			},
相关推荐
智算菩萨1 分钟前
实战:高级中文自然语言处理系统的Python设计与实现
前端·javascript·easyui
幼儿园老大42 分钟前
告别代码屎山!UniApp + Vue3 自动化规范:ESLint 9+ 扁平化配置全指南
javascript·vue.js
Liu.7741 小时前
vue3组件之间传输数据
前端·javascript·vue.js
|晴 天|1 小时前
前端闭包:从概念到实战,解锁JavaScript高级技能
开发语言·前端·javascript
2501_915918411 小时前
TCP 抓包分析在复杂网络问题中的作用,从连接和数据流层面理解系统异常行为
网络·网络协议·tcp/ip·ios·小程序·uni-app·iphone
全栈前端老曹2 小时前
【ReactNative】核心组件与 JSX 语法
前端·javascript·react native·react.js·跨平台·jsx·移动端开发
じòぴé南冸じょうげん2 小时前
APP本地调试正常,但是打包后出现账号密码解析错误,且前端未使用加密解密
小程序·uni-app·web app
小小黑0072 小时前
快手小程序-实现插屏广告的功能
前端·javascript·小程序
@万里挑一2 小时前
vue中使用虚拟列表,封装虚拟列表
前端·javascript·vue.js
黑臂麒麟2 小时前
Electron for OpenHarmony 跨平台实战开发:Electron 文件系统操作实战
前端·javascript·electron·openharmony