0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

鸿蒙开发接口数据管理:【@ohos.data.preferences (首选项)】

jf_46214456 来源:jf_46214456 作者:jf_46214456 2024-06-10 18:46 次阅读

首选项

首选项为应用提供key-value键值型的数据处理能力,支持应用持久化轻量级数据,并对其修改和查询。数据存储形式为键值对,键的类型为字符串型,值的存储数据类型包括数字型、字符型、布尔型。

说明: 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 开发前请熟悉鸿蒙开发指导文档 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

导入模块

import data_preferences from '@ohos.data.preferences';

常量

系统能力: 以下各项对应的系统能力均为SystemCapability.DistributedDataManager.Preferences.Core

名称参数类型可读可写说明
MAX_KEY_LENGTHstringkey的最大长度限制,需小于80字节。
MAX_VALUE_LENGTHstringvalue的最大长度限制,需小于8192字节。

data_preferences.getPreferences

getPreferences(context: Context, name: string, callback: AsyncCallback): void

读取指定首选项持久化文件,将数据加载到Preferences实例,用于数据操作,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。
callbackAsyncCallback<[Preferences]>回调函数。

示例:

data_preferences.getPreferences(this.context, 'mystore', function (err, preferences) {
    if (err) {
        console.info("Get preferences failed.")
        return;
    }
    console.info("Get preferences successfully.")
})

data_preferences.getPreferences

getPreferences(context: Context, name: string): Promise

读取指定首选项持久化文件,将数据加载到Preferences实例,用于数据操作,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。

返回值:

类型说明
Promise<[Preferences]>Promise实例,用于异步获取结果。

示例:

let promise = data_preferences.getPreferences(this.context, 'mystore')
promise.then((preferences) = > {
    console.info("Get preferences successfully.")
}).catch((err) = > {
    console.info("Get preferences failed.")
})

data_preferences.deletePreferences

deletePreferences(context: Context, name: string, callback: AsyncCallback): void

从内存中移除指定首选项持久化文件对应的Preferences单实例,并删除指定文件及其备份文件和损坏文件。 删除指定首选项持久化文件时,应用不允许再使用该实例进行数据操作,否则会出现数据一致性问题,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。
callbackAsyncCallback回调函数。

示例:

data_preferences.deletePreferences(this.context, 'mystore', function (err) {
    if (err) {
        console.info("Deleted preferences failed, err: " + err)
        return
    }
    console.info("Deleted preferences successfully.")
})

data_preferences.deletePreferences

deletePreferences(context: Context, name: string): Promise

从内存中移除指定首选项持久化文件对应的Preferences单实例,并删除指定文件及其备份文件和损坏文件。 删除指定首选项持久化文件时,应用不允许再使用该实例进行数据操作,否则会出现数据一致性问题,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。

返回值:

类型说明
PromisePromise实例,用于异步获取结果。

示例:

let promise = data_preferences.deletePreferences(this.context, 'mystore')
promise.then(() = > {
    console.info("Deleted preferences successfully.")
}).catch((err) = > {
    console.info("Deleted preferences failed, err: " + err)
})

data_preferences.removePreferencesFromCache

removePreferencesFromCache(context: Context, name: string, callback: AsyncCallback): void

从内存中移除指定首选项持久化文件对应的Preferences单实例。

移除Preferences单实例时,应用不允许再使用该实例进行数据操作,否则会出现数据一致性问题,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。
callbackAsyncCallback回调函数。

示例:

data_preferences.removePreferencesFromCache(this.context, 'mystore', function (err) {
    if (err) {
        console.info("Removed preferences from cache failed, err: " + err)
        return
    }
    console.info("Removed preferences from cache successfully.")
})

data_preferences.removePreferencesFromCache

removePreferencesFromCache(context: Context, name: string): Promise

从内存中移除指定首选项持久化文件对应的Preferences单实例。

移除Preferences单实例时,应用不允许再使用该实例进行数据操作,否则会出现数据一致性问题,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
context[Context]应用程序或功能的上下文。
namestring应用程序内部数据存储名称。

返回值:

类型说明
PromisePromise实例,用于异步获取结果。

示例:

let promise = data_preferences.removePreferencesFromCache(this.context, 'mystore')
promise.then(() = > {
    console.info("Removed preferences from cache successfully.")
}).catch((err) = > {
    console.info("Removed preferences from cache failed, err: " + err)
})

Preferences

提供获取和修改存储数据的接口。

get

get(key: string, defValue: ValueType, callback: AsyncCallback): void

获取键对应的值,如果值为null或者非默认值类型,返回默认数据,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要获取的存储key名称,不能为空。
defValue[ValueType]默认返回值。支持number、string、boolean。
callbackAsyncCallback回调函数。

示例:

preferences.get('startup', 'default', function(err, value) {
    if (err) {
        console.info("Get value of startup failed, err: " + err)
        return
    }
    console.info("Get value of startup is " + value)
})

get

get(key: string, defValue: ValueType): Promise

获取键对应的值,如果值为null或者非默认值类型,返回默认数据,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

  • 参数:
    参数名类型必填说明
    keystring要获取的存储key名称,不能为空。
    defValue[ValueType]默认返回值。支持number、string、boolean。

返回值:

类型说明
PromisePromise实例,用于异步获取结果。

示例:

let promise = preferences.get('startup', 'default')
promise.then((value) = > {
    console.info("Get value of startup is " + value)
}).catch((err) = > {
    console.info("Get value of startup failed, err: " + err)
})

getAll

getAll(callback: AsyncCallback ): void;

返回含有所有键值的Object对象。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
callbackAsyncCallback回调函数。返回含有所有键值的Object对象。

示例:

preferences.getAll(function (err, value) {
    if (err) {
        console.info("getAll failed, err: " + err)
        return
    }
    let keys = Object.keys(value)
    console.info('getAll keys = ' + keys)
    console.info("getAll object = " + JSON.stringify(value))
});

getAll

getAll(): Promise

返回含有所有键值的Object对象。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

返回值:

类型说明
PromisePromise对象。返回含有所有键值的Object对象。

示例:

let promise = preferences.getAll()
promise.then((value) = > {
    let keys = Object.keys(value)
    console.info('getAll keys = ' + keys)
    console.info("getAll object = " + JSON.stringify(value))
}).catch((err) = > {
    console.info("getAll failed, err: " + err)
})

put

put(key: string, value: ValueType, callback: AsyncCallback): void

首先获取指定首选项持久化文件对应的Preferences实例,然后借助Preferences API将数据写入Preferences实例,通过flush或者flushSync将Preferences实例持久化,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要修改的存储的key,不能为空。
value[ValueType]存储的新值。支持number、string、boolean。
callbackAsyncCallback回调函数。

示例:

preferences.put('startup', 'auto', function (err) {
    if (err) {
        console.info("Put value of startup failed, err: " + err)
        return
    }
    console.info("Put value of startup successfully.")
})

put

put(key: string, value: ValueType): Promise

首先获取指定首选项持久化文件对应的Preferences实例,然后借助Preferences API将数据写入Preferences实例,通过flush或者flushSync将Preferences实例持久化,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要修改的存储的key,不能为空。
value[ValueType]存储的新值。支持number、string、boolean。

返回值:

类型说明
PromisePromise实例,用于异步处理。

示例:

let promise = preferences.put('startup', 'auto')
promise.then(() = > {
    console.info("Put value of startup successfully.")
}).catch((err) = > {
    console.info("Put value of startup failed, err: " + err)
})

has

has(key: string, callback: AsyncCallback): void

检查存储对象是否包含名为给定key的存储键值对,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要检查的存储key名称,不能为空。
callbackAsyncCallback回调函数。返回存储对象是否包含给定key的存储键值对,true表示存在,false表示不存在。

示例:

preferences.has('startup', function (err, isExist) {
    if (err) {
        console.info("Check the key of startup failed, err: " + err)
        return
    }
    if (isExist) {
        console.info("The key of startup is contained.")
    } else {
        console.info("The key of startup dose not contain.")
    }
})

has

has(key: string): Promise

检查存储对象是否包含名为给定key的存储键值对,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要检查的存储key名称,不能为空。

返回值:

类型说明
PromisePromise对象。返回存储对象是否包含给定key的存储键值对,true表示存在,false表示不存在。

示例:

let promise = preferences.has('startup')
promise.then((isExist) = > {
    if (isExist) {
        console.info("The key of startup is contained.")
    } else {
        console.info("The key of startup dose not contain.")
    }
}).catch((err) = > {
    console.info("Check the key of startup failed, err: " + err)
})

delete

delete(key: string, callback: AsyncCallback): void

从存储对象中删除名为给定key的存储键值对,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要删除的存储key名称,不能为空。
callbackAsyncCallback回调函数。

示例:

preferences.delete('startup', function (err) {
    if (err) {
        console.info("Delete startup key failed, err: " + err)
        return
    }
    console.info("Deleted startup key successfully.")
})

delete

delete(key: string): Promise

从存储对象删除名为给定key的存储键值对,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
keystring要删除的存储key名称,不能为空。

返回值:

类型说明
PromisePromise实例,用于异步处理。

示例:

let promise = preferences.delete('startup')
promise.then(() = > {
    console.info("Deleted startup key successfully.")
}).catch((err) = > {
    console.info("Delete startup key failed, err: " + err)
})

flush

flush(callback: AsyncCallback): void

将当前preferences对象中的修改保存到当前的preferences,并异步存储到首选项持久化文件中,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
callbackAsyncCallback回调函数。

示例:

preferences.flush(function (err) {
    if (err) {
        console.info("Flush to file failed, err: " + err)
        return
    }
    console.info("Flushed to file successfully.")
})

flush

flush(): Promise

将当前preferences对象中的修改保存到当前的preferences,并异步存储到首选项持久化文件中,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

返回值:

类型说明
PromisePromise实例,用于异步处理。

示例:

let promise = preferences.flush()
promise.then(() = > {
    console.info("Flushed to file successfully.")
}).catch((err) = > {
    console.info("Flush to file failed, err: " + err)
})

clear

clear(callback: AsyncCallback): void

清除此存储对象中的所有存储,该方法使用callback方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
callbackAsyncCallback回调函数。

示例:

preferences.clear(function (err) {
    if (err) {
        console.info("Clear to file failed, err: " + err)
        return
    }
    console.info("Cleared to file successfully.")
})

clear

clear(): Promise

清除此存储对象中的所有存储,该方法使用Promise方式作为异步方法。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

返回值:

类型说明
PromisePromise实例,用于异步处理。

示例:

let promise = preferences.clear()
promise.then(() = > {
    console.info("Cleared to file successfully.")
}).catch((err) = > {
    console.info("Clear to file failed, err: " + err)
})

on('change')

on(type: 'change', callback: Callback<{ key : string }>): void

订阅数据变更者类,订阅的key的值发生变更后,在执行flush方法后,callback方法会被回调。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明
typestring事件类型,固定值'change',表示数据变更。
callbackCallback<{ key : string }>回调对象实例。

示例:

data_preferences.getPreferences(this.context, 'mystore', function (err, preferences) {
    if (err) {
        console.info("Get preferences failed.")
        return;
    }
    var observer = function (key) {
        console.info("The key of " + key + " changed.")
    }
    preferences.on('change', observer)
    preferences.put('startup', 'auto', function (err) {
        if (err) {
            console.info("Put the value of startup failed, err: " + err)
            return
        }
        console.info("Put the value of startup successfully.")

        preferences.flush(function (err) {
            if (err) {
                console.info("Flush to file failed, err: " + err)
                return
            }
            console.info("Flushed to file successfully.") // observer will be called.
        })
    })
})

off('change')

off(type: 'change', callback?: Callback<{ key : string }>): void

当不再进行订阅数据变更时,使用此接口取消订阅。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

参数:

参数名类型必填说明HarmonyOSOpenHarmony鸿蒙文档籽料:mau123789是v直接拿
typestring事件类型,固定值'change',表示数据变更。
callbackCallback<{ key : string }>需要取消的回调对象实例,不填则全部取消。

示例:

data_preferences.getPreferences(this.context, 'mystore', function (err, preferences) {
    if (err) {
        console.info("Get preferences failed.")
        return;
    }
    var observer = function (key) {
        console.info("The key of " + key + " changed.")
    }
    preferences.on('change', observer)
    preferences.put('startup', 'auto', function (err) {
        if (err) {
            console.info("Put the value of startup failed, err: " + err)
            return
        }
        console.info("Put the value of startup successfully.")

        preferences.flush(function (err) {
            if (err) {
                console.info("Flush to file failed, err: " + err)
                return
            }
            console.info("Flushed to file successfully.") // observer will be called.
        })
        preferences.off('change', observer)
    })
})

ValueType

用于表示允许的数据字段类型。

系统能力: SystemCapability.DistributedDataManager.Preferences.Core

名称说明
number表示值类型为数字。
string表示值类型为字符串。
boolean表示值类型为布尔值。

审核编辑 黄宇

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • 接口
    +关注

    关注

    33

    文章

    7963

    浏览量

    149211
  • 数据管理
    +关注

    关注

    1

    文章

    270

    浏览量

    19494
  • 鸿蒙
    +关注

    关注

    55

    文章

    2090

    浏览量

    42261
收藏 人收藏

    评论

    相关推荐

    鸿蒙OS开发实例:【工具类封装-首选项本地存储】

    **import dataPreferences from '@ohos.data.preferences'; import bundleManager from '@ohos.bundle.bundleManager';**
    的头像 发表于 03-28 15:45 1033次阅读
    <b class='flag-5'>鸿蒙</b>OS<b class='flag-5'>开发</b>实例:【工具类封装-<b class='flag-5'>首选项</b>本地存储】

    HarmonyOS开发案例:【用户首选项

    用户首选项为应用提供Key-Value键值型的数据处理能力,支持应用持久化轻量级数据,常用于保存应用配置信息、用户偏好设置等。本篇Codelab将基于用户首选项实现一个简单的
    的头像 发表于 04-18 15:34 583次阅读
    HarmonyOS<b class='flag-5'>开发</b>案例:【用户<b class='flag-5'>首选项</b>】

    HarmonyOS开发案例:【首选项

    基于HarmonyOS的首选项能力实现的一个简单示例。
    的头像 发表于 04-19 16:20 971次阅读
    HarmonyOS<b class='flag-5'>开发</b>案例:【<b class='flag-5'>首选项</b>】

    鸿蒙实战项目开发:【短信服务】

    数据管理 电话服务 分布式应用开发 通知与窗口管理 多媒体技术 安全技能 任务管理 WebGL 国际化开发 应用测试 DFX面向未来设计
    发表于 03-03 21:29

    如何设置Xilinx ISE首选项11.x 12.x的默认值

    可能是一个新手问题,我们有一个配置允许不同版本的附加工具,如modelsim,synplicity。我们想知道是否有办法告诉Xilinx默认使用什么。具体来说,我们有兴趣设置以下值: 首选项
    发表于 11-15 11:29

    无法使用Vee 9.22 Runtime禁用编译器警告

    您好,在版本8.5中,您可以在“默认首选项”中禁用Vee开发环境和运行时的编译器警告。现在我的版本为9.2。在开发环境中,您可以禁用编译器警告,但不能禁用运行时版本。此项目将不再出现在“默认
    发表于 03-26 15:26

    查看首选项未保存, 如何保存设置?

    您好,我想把论坛中的帖子看成“平面阅读模式”而不是“线程阅读模式”。所以我转到用户控制面板,编辑配置文件,特性首选项,查看首选项,并将其设置为“平面”,然后单击“保存配置文件”。如果我移动到其他
    发表于 09-11 12:08

    数据管理功能详解

    在应用程序菜单上,单击设置→选项管理,勾选使用浩辰3D软件的数据管理。在管理页面上,可以通过选项卡来快速搜索保管库定义、定制属性、文件命名
    发表于 11-03 15:32

    OpenHarmony标准设备应用开发(三)——分布式数据管理

    /js-apis-distributed-data.md数据分布式运作示意图,如下所示。实现步骤:分布式数据管理依赖 @ohos.data.distributedData 模块实现,详
    发表于 04-07 18:48

    【学习打卡】OpenHarmony的分布式数据管理介绍

    使用它来做出更明智的决策,如果一个系统缺乏适当的数据管理,那就可能会导致数据孤岛、数据集之间不一致,甚至数据本身存在错误。有效的分布式数据管理
    发表于 07-15 15:49

    ESP8266/ARDUINO构建H找不到首选项怎么解决?

    大家好!我对运行 Arduino 核心的 ESP32 有一些扎实的经验,并且一直在使用首选项库来存储,你猜对了,首选项,到该平台上的 NVS。这是一个简单而顺利的过程。我正在尝试将我的代码移植到运行
    发表于 02-21 07:44

    HarmonyOS数据管理与应用数据持久化(一)

    开发步骤 导入用户首选项模块。 import dataPreferences from \'@ohos.data.preferences\'; 要通过用户首选项实现
    发表于 11-01 16:27

    工业现场数据管理 | 什么是工业现场数据管理

    数据管理,以传输层/云作为界限,将其以下的所有南侧的车间、工厂、控制站点等工业现场封装成一个有序的“黑盒子”,并向外提供标准的通讯、数据和服务接口,便于各类平台、应用或云系统与工业现场进行数据
    的头像 发表于 04-28 19:08 2043次阅读

    鸿蒙HarmonyOS开发实例:【分布式关系型数据库】

    使用[@ohos.data.relationalStore]接口和[@ohos.distributedDeviceManager] 接口展示了在eTS中分布式关系型
    的头像 发表于 04-11 09:52 387次阅读
    <b class='flag-5'>鸿蒙</b>HarmonyOS<b class='flag-5'>开发</b>实例:【分布式关系型<b class='flag-5'>数据</b>库】

    鸿蒙开发接口数据管理:【@ohos.data.rdb (关系型数据库)】

    关系型数据库(Relational Database,RDB)是一种基于关系模型来管理数据数据库。关系型数据库基于SQLite组件提供了一
    的头像 发表于 06-10 18:35 539次阅读