Last updated:
0 purchases
local cache sync
local_cache_sync #
一个非常简单易用的Flutter本地储存库,适用于在本地储存一列轻量数据(例如用户保存在本地的设备信息,或者缓存一系列用户信息)。
local_cache_sync的所有方法都是同步,而不是异步的。这意味着你不需要使用await就可以获取数据。在flutter中,这可以显著减少StatefulWidget的数量,大量减少代码的复杂度。
Start #
pubspec.yaml
path_provider: ^1.4.5
local_cache_sync: ^1.2.1
copied to clipboard
Set Cache Path.
After 1.2.0:
void main() async {
WidgetsFlutterBinding.ensureInitialized();
LocalCacheSync.instance.setCachePath(
await getTemporaryDirectory(),
'example_app/',
);
// Can set special path to UserDefaultSync
UserDefaultSync.setCachePath(
await getApplicationSupportDirectory(),
'example_app/',
);
runApp(MyApp());
}
copied to clipboard
Before(less than or equal to 1.1.1):
getTemporaryDirectory().then((uri) {
LocalCacheSync.instance.setCachePath(uri.path);
});
copied to clipboard
User Default Demo #
Switch组件的值会被缓存到本地,即使重新启动App也会保留
使用local_cache_sync保存与读取参数都是同步的,这意味着赋值即是保存,而且在StatelessWidget中,可以立即使用数据。
基础用法
Switch(
value: LocalCacheSync.userDefault.getWithKey<bool>('switch-A'),
onChanged: (v) {
setState(() {
LocalCacheSync.userDefault.setWithKey<bool>('switch-A', v);
});
},
),
copied to clipboard
更方便的使用方法(推荐)
// Creat class:
class MySetting {
static var autoLogin = const DefaultValueCache<bool>('autoLogin', false);
}
// build
Switch(
value: MySetting.autoLogin.value,
onChanged: (v) {
setState(()=>MySetting.autoLogin.value = v);
},
),
copied to clipboard
Usage: User Default Cache 用户偏好设置缓存 #
使用local_cache_sync实现保存用户自定义设置非常简单,只需要赋值与取值,无需异步等待,即可保存参数到本地。
读取参数也是同步的,这意味着你可以在StatelessWidget中立即使用数据。
Use Function: #
Save values
LocalCacheSync.userDefault.setWithKey<bool>('isDarkMode',true);
LocalCacheSync.userDefault.setWithKey<String>('token','aabbccdd');
LocalCacheSync.userDefault.setWithKey<Map>('x-config',{'id':1243});
copied to clipboard
Read values
var res = LocalCacheSync.userDefault.getWithKey<bool>('isDarkMode');
var res = LocalCacheSync.userDefault.getWithKey<String>('token');
var res = LocalCacheSync.userDefault.getWithKey<Map>('x-config');
copied to clipboard
Use operator: #
Save values
LocalCacheSync.userDefault['isDarkMode'] = true;
LocalCacheSync.userDefault['token'] = 'aabbccdd';
LocalCacheSync.userDefault['x-config'] = {'id':1243};
copied to clipboard
Read values
bool res = LocalCacheSync.userDefault['isDarkMode'];
String res = LocalCacheSync.userDefault['token'];
Map res = LocalCacheSync.userDefault['x-config'];
copied to clipboard
DefaultValueCache #
Eazy used with static property.
只需要静态属性就可以使用缓存,并为缓存指定默认值,不担心缓存为空。
// Creat class:
class ProjectCustomUserDefault {
static var autoLogin = const DefaultValueCache<bool>('autoLogin', false);
}
// save
ProjectCustomUserDefault.autoLogin.value = true;
// read
bool isAutoLogin = ProjectCustomUserDefault.autoLogin.value
copied to clipboard
Usage: Table Cache 列表管理 #
如果你需要管理一系列值,请使用LocalCacheLoader,只需要一个channel标志,你就可以管理一系列值。
Lazy Load #
LocalCacheLoader在内部实现了懒加载的效果:只有取value属性时数据才真正被加载。
在应用中,假如你有1-100号设备显示在Listview.builder中,只有100号设备即将进入屏幕中时,100号设备的缓存参数才会被真正加载。也就是说LocalCacheLoader不会导致长列表卡顿。
Model Example #
我推荐你这样创建你的model:
Create class load from loader.
class Device {
final String uuid;
final String name;
final int type;
Device({
this.uuid,
this.name,
this.type,
});
Device.fromJson(Map<String, dynamic> map)
: this(
uuid: map['uuid'],
name: map['name'],
type: map['type'],
);
static LocalCacheLoader get _loader => LocalCacheLoader('device');
static List<Device> all() {
return _loader.all
.map<Device>(
(cache) => Device.fromJson(cache.value),
)
.toList();
}
// LocalCacheObject仅在取出Value时进行数据加载
// 在数据很大时,这样可以提升列表加载性能
static List<LocalCacheObject> allWithLazyLoad() {
return _loader.all;
}
LocalCacheObject save() {
return Device._loader.saveById(uuid, jsonMap);
}
Map<String, dynamic> get jsonMap => {
'uuid': uuid,
'name': name,
'type': type,
};
}
copied to clipboard
你也可以另外封装loader来读写其他信息,对于轻量级的储存,以上是非常简单易用的。
Cache Detail Overview #
可以快速查看保存的数据:
LocalCacheSync.pushDetailPage(context)
copied to clipboard
警告 #
不要在io密集型场景使用local_cache_sync,例如即时储存每秒10次的扫描结果。
虽然flutter中阻塞主线程不会导致UI卡顿,但是你仍不应当在io密集型场景使用,这超出了local_cache_sync设计的工作范围。
致谢 #
图片缓存功能修改自:https://github.com/pedia/file_cache 。感谢原作者的贡献。
For personal and professional use. You cannot resell or redistribute these repositories in their original state.
There are no reviews.