harmony-utils之PreferencesUtil,首选项工具类

简介: `PreferencesUtil` 是 HarmonyOS 工具库 `harmony-utils` 中的首选项工具类,提供便捷的数据缓存与管理功能。支持初始化、存储、获取、删除等操作,并具备订阅数据变更的能力,助力高效开发。

harmony-utils之PreferencesUtil,首选项工具类

harmony-utils 简介与说明


harmony-utils 一款功能丰富且极易上手的HarmonyOS工具库,借助众多实用工具类,致力于助力开发者迅速构建鸿蒙应用。其封装的工具涵盖了APP、设备、屏幕、授权、通知、线程间通信、弹框、吐司、生物认证、用户首选项、拍照、相册、扫码、文件、日志,异常捕获、字符、字符串、数字、集合、日期、随机、base64、加密、解密、JSON等一系列的功能和操作,能够满足各种不同的开发需求。
picker_utils 是harmony-utils拆分出来的一个子库,包含PickerUtil、PhotoHelper、ScanUtil。

下载安装
ohpm i @pura/harmony-utils
ohpm i @pura/picker_utils

  //全局初始化方法,在UIAbility的onCreate方法中初始化 AppUtil.init()
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    AppUtil.init(this.context);
  }

API方法与使用


init 初始化
 PreferencesUtil.init("my_app_preferences");
put 将数据缓存
PreferencesUtil.put("id", 10000018);
PreferencesUtil.putSync("name", "张三叁");
PreferencesUtil.putSync("bl_nuv", false);
get 获取缓存值
 let id = await PreferencesUtil.get("id", "");
getString 获取string类型的缓存值
let name1 = await PreferencesUtil.getString("name");
let name2 = PreferencesUtil.getStringSync('name');
getNumber 获取number类型的缓存值
let id1 = await PreferencesUtil.getNumber("id");
let id2 = PreferencesUtil.getNumberSync('id');
getBoolean 获取boolean类型的缓存值
let bl1 = await PreferencesUtil.getBoolean("bl_nut");
let bl2 = PreferencesUtil.getBooleanSync('bl_nuv');
has 检查缓存实例中是否包含给定Key的存储键值对
let bl1 = await PreferencesUtil.has("id");
let bl2 = PreferencesUtil.hasSync('name');
delete 删除缓存值
PreferencesUtil.delete("id");
PreferencesUtil.deleteSync("name");
clear 清空缓存
PreferencesUtil.clear();
PreferencesUtil.clearSync();
deletePreferences 从缓存中移出指定的Preferences实例,若Preferences实例有对应的持久化文件,则同时删除其持久化文件。
 PreferencesUtil.deletePreferences(getContext(), "SP_PREFERENCES_MSG");
onChange 订阅数据变更,订阅的Key的值发生变更后,在执行flush方法后,触发callback回调
  private callback: Callback<string> = (value) => {
    LogUtil.error("onChange: " + value);
  }

 PreferencesUtil.onChange(callback);
offChange 取消订阅数据变更
 PreferencesUtil.offChange(callback);
onDataChange 精确订阅数据变更,只有被订阅的key值发生变更后,在执行flush方法后,触发callback回调
  private dataCallback = (data: Record<string, preferences.ValueType>) => {
    for (const keyValue of Object.entries(data)) {
      LogUtil.error("onDataChange: " + keyValue);
    }
  }

  PreferencesUtil.onDataChange(["id", "name"], dataCallback);
offDataChange 取消精确订阅数据变更
PreferencesUtil.offDataChange(["id", "name"], dataCallback);

创作不易,请给童长老点赞👍


https://github.com/787107497/harmony-utils
https://gitee.com/tongyuyan/harmony-utils
OpenHarmony三方库

目录
相关文章
|
9月前
|
前端开发 开发者
HarmonyOS实战:自定义时间选择器
在鸿蒙开发中,官方提供的默认时间选择器可能无法满足特定需求。本文分享了自定义时间选择器的实现过程:通过 TextPicker 控件实现年月日及时分的选择,支持默认选中当前时间、精确到时分,并注意闰年计算与日期格式处理。代码中使用 Promise 处理耗时的日期计算,确保显示和逻辑正确。总结指出,尽管看似简单,但需关注时间计算、格式化等细节。快动手试试吧!
378 1
|
10月前
|
JavaScript 前端开发 物联网
ArkTs的@Watch状态监听
@Watch是ArkUI框架中用于监听状态变量变化的核心工具,类似Vue的Watch机制。状态更新时,方法触发,通过`changedPropertyName`区分多个绑定变量。需与@State、@Prop、@Link等装饰器配合使用,顺序上须置于这些装饰器之后。实际开发中,@Watch常与@Link(跨组件双向同步)或@Provide(跨代组件同步)结合使用。例如,通过@Link接收父组件变量并监听变化,动态调整子组件状态;或利用@Provide定义全局变量,监听后更新整体进度状态。这种机制提升了组件间状态管理的灵活性与解耦性,助力开发者高效构建复杂应用,实现“一次开发,多端部署”的目标。
550 15
|
Apache 开发者
最受欢迎的三方库之SpinKit
SpinKit 是一款适用于 OpenHarmony/HarmonyOS 的加载动画库,提供多种动画类型与自定义配置,帮助开发者轻松实现美观的加载效果。
259 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PasteboardUtil,剪贴板工具类
harmony-utils 是一款功能丰富且易用的 HarmonyOS 工具库,提供剪贴板、设备、屏幕、授权等常用工具类,助力开发者高效构建鸿蒙应用。
182 0
|
8月前
|
JSON 生物认证 API
harmony-utils之FormatUtil,格式化工具类
FormatUtil 是 harmony-utils 工具库中的格式化工具类,提供电话号码验证与格式化、中文转拼音、百分比显示、文件大小转换、文本截取、URL参数解析与拼接等功能,助力鸿蒙应用快速开发。
179 0
|
8月前
|
JSON 缓存 生物认证
harmony-utils之FileUtil,文件相关工具类
FileUtil是HarmonyOS工具库harmony-utils中的文件操作工具类,提供丰富的文件管理功能,包括路径处理、文件读写、目录操作、文件属性获取等。它简化了HarmonyOS应用开发中的文件操作流程,提升开发效率。
271 0
|
8月前
|
JSON 生物认证 API
harmony-utils之EmitterUtil,Emitter工具类
harmony-utils之EmitterUtil是一款HarmonyOS应用开发中的事件通信工具类,支持事件的发送、订阅、单次订阅、取消订阅及订阅数查询等操作。它基于高效的事件驱动机制,简化了模块间的通信流程,提升开发效率,适用于复杂场景下的事件管理。
191 0
|
8月前
|
JSON 安全 生物认证
harmony-utils之NumberUtil,Number工具类
NumberUtil 是 HarmonyOS 工具库 harmony-utils 中的数字工具类,提供丰富的数值处理方法,如判断NaN、有限数、整数、安全整数、奇偶性,数值转换、加减乘除及求和等,助力高效开发。
262 0
|
8月前
|
JSON 前端开发 生物认证
harmony-utils之DisplayUtil,屏幕相关工具类
DisplayUtil 是 harmony-utils 中的屏幕相关工具类,提供多种屏幕信息获取与监听功能。支持获取屏幕宽高、方向、状态、折叠信息及截屏投屏状态等,适用于鸿蒙应用开发,提升开发效率。
180 0
|
8月前
|
JSON 生物认证 API
harmony-utils之PreviewUtil,文件预览工具类
PreviewUtil 是 harmony-utils 工具库中的文件预览工具类,提供生成预览信息、打开/关闭预览窗口、加载预览数据、判断预览支持等功能,助力鸿蒙应用快速实现文件预览操作。
278 0