写点什么

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

  • 2025-06-26
    安徽
  • 本文字数:1382 字

    阅读完需:约 5 分钟

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三方库


童长老CSDN博客

用户头像

还未添加个人签名 2025-05-14 加入

还未添加个人简介

评论

发布
暂无评论
harmony-utils之PreferencesUtil,首选项工具类_HarmonyOS_桃花镇童长老_InfoQ写作社区