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

目录
相关文章
|
前端开发 开发者
HarmonyOS实战:自定义时间选择器
在鸿蒙开发中,官方提供的默认时间选择器可能无法满足特定需求。本文分享了自定义时间选择器的实现过程:通过 TextPicker 控件实现年月日及时分的选择,支持默认选中当前时间、精确到时分,并注意闰年计算与日期格式处理。代码中使用 Promise 处理耗时的日期计算,确保显示和逻辑正确。总结指出,尽管看似简单,但需关注时间计算、格式化等细节。快动手试试吧!
465 1
|
11月前
|
编解码 缓存 开发工具
HarmonyOS NEXT实战:字符串工具
本课程讲解如何在HarmonyOS Next中使用ArkTS语言封装字符串工具类,实现字符串空值判断、编码转换、Base64编解码等功能,帮助开发者高效处理字符串操作。
349 1
|
Apache 开发者
最受欢迎的三方库之SpinKit
SpinKit 是一款适用于 OpenHarmony/HarmonyOS 的加载动画库,提供多种动画类型与自定义配置,帮助开发者轻松实现美观的加载效果。
306 0
|
11月前
|
JSON 生物认证 API
harmony-utils之ObjectUtil,对象工具类
`harmony-utils` 是一款专为 HarmonyOS 开发的功能强大且易于使用的工具库,涵盖对象操作、设备信息、文件处理、数据加密等常用开发功能,帮助开发者快速构建高效稳定的鸿蒙应用。
226 0
|
11月前
|
JSON 生物认证 API
harmony-utils之LocationUtil,定位相关工具类
harmony-utils 是一款专为 HarmonyOS 开发的高效工具库,包含丰富的实用类与功能模块。其中 LocationUtil 提供了定位服务判断、权限申请、位置获取、地理编码、坐标转换等功能,帮助开发者快速实现定位相关操作,提升开发效率。
242 0
|
11月前
|
存储 JSON 生物认证
harmony-utils之KvUtil,键值型数据库工具类
harmony-utils之KvUtil是鸿蒙系统中用于操作键值型数据库的工具类,提供包括添加、获取、删除、批量操作及备份恢复等功能,简化数据存储与管理。
210 0
|
11月前
|
JSON 生物认证 API
harmony-utils之PasteboardUtil,剪贴板工具类
harmony-utils 是一款功能丰富且易用的 HarmonyOS 工具库,提供剪贴板、设备、屏幕、授权等常用工具类,助力开发者高效构建鸿蒙应用。
228 0
|
11月前
|
JSON 生物认证 API
harmony-utils之ImageUtil,图片相关工具类
harmony-utils 是一款功能丰富的 HarmonyOS 工具库,提供包括图像处理在内的多种实用工具类。ImageUtil 作为其子模块,专注于图片相关操作,支持 Base64 与 PixelMap 转换、图片压缩、保存及编码打包等功能,助力开发者高效实现图片处理需求。
860 0
|
11月前
|
JSON 生物认证 API
harmony-utils之FormatUtil,格式化工具类
FormatUtil 是 harmony-utils 工具库中的格式化工具类,提供电话号码验证与格式化、中文转拼音、百分比显示、文件大小转换、文本截取、URL参数解析与拼接等功能,助力鸿蒙应用快速开发。
236 0
|
11月前
|
JSON 缓存 生物认证
harmony-utils之FileUtil,文件相关工具类
FileUtil是HarmonyOS工具库harmony-utils中的文件操作工具类,提供丰富的文件管理功能,包括路径处理、文件读写、目录操作、文件属性获取等。它简化了HarmonyOS应用开发中的文件操作流程,提升开发效率。
346 0

热门文章

最新文章