RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

HarmonyOS開(kāi)發(fā)案例:【首選項(xiàng)】

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-19 16:20 ? 次閱讀

介紹

基于HarmonyOS的首選項(xiàng)能力實(shí)現(xiàn)的一個(gè)簡(jiǎn)單示例。實(shí)現(xiàn)如下功能:

  1. 創(chuàng)建首選項(xiàng)數(shù)據(jù)文件。
  2. 將用戶輸入的水果名稱和數(shù)量,寫(xiě)入到首選項(xiàng)數(shù)據(jù)庫(kù)。
  3. 讀取首選項(xiàng)數(shù)據(jù)庫(kù)中的數(shù)據(jù)。
  4. 刪除首選項(xiàng)數(shù)據(jù)文件。

最終效果圖如下:

相關(guān)概念

  • [首選項(xiàng)]:為應(yīng)用提供Key-Value鍵值型的數(shù)據(jù)處理能力,支持應(yīng)用持久化輕量級(jí)數(shù)據(jù),并對(duì)其修改和查詢。數(shù)據(jù)存儲(chǔ)形式為鍵值對(duì),鍵的類型為字符串型,值的存儲(chǔ)數(shù)據(jù)類型包括數(shù)字型、字符型、布爾型以及這3種類型的數(shù)組類型。
  • [TextInput]:可以輸入單行文本并支持響應(yīng)輸入事件的組件。
  • [Button]:按鈕組件,可快速創(chuàng)建不同樣式的按鈕。

環(huán)境搭建

軟件要求

  • [DevEco Studio]版本:DevEco Studio 3.1 Release。
  • OpenHarmony SDK版本:API version 9。

硬件要求

  • 開(kāi)發(fā)板類型:[潤(rùn)和RK3568開(kāi)發(fā)板]。
  • OpenHarmony系統(tǒng):3.2 Release。

環(huán)境搭建

完成本篇Codelab我們首先要完成開(kāi)發(fā)環(huán)境的搭建,本示例以RK3568開(kāi)發(fā)板為例,參照以下步驟進(jìn)行:

  1. [獲取OpenHarmony系統(tǒng)版本]:標(biāo)準(zhǔn)系統(tǒng)解決方案(二進(jìn)制)。以3.2 Release版本為例:
  2. 搭建燒錄環(huán)境。
    1. [完成DevEco Device Tool的安裝]
    2. [完成RK3568開(kāi)發(fā)板的燒錄](méi)
    3. 鴻蒙開(kāi)發(fā)指導(dǎo)文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]
  3. 搭建開(kāi)發(fā)環(huán)境。
    1. 開(kāi)始前請(qǐng)參考[工具準(zhǔn)備],完成DevEco Studio的安裝和開(kāi)發(fā)環(huán)境配置。
    2. 開(kāi)發(fā)環(huán)境配置完成后,請(qǐng)參考[使用工程向?qū)創(chuàng)建工程(模板選擇“Empty Ability”)。
    3. 工程創(chuàng)建完成后,選擇使用[真機(jī)進(jìn)行調(diào)測(cè)]。

代碼結(jié)構(gòu)解讀

本篇Codelab只對(duì)核心代碼進(jìn)行講解,完整代碼可以直接從gitee獲取。

├──entry/src/main/ets              // 代碼區(qū)
│  ├──common
│  │  ├──constants
│  │  │  ├──CommonConstants.ets    // 公共常量類
│  │  │  └──StyleConstants.ets     // 樣式常量類 
│  │  └──utils
│  │     └──Logger.ets             // 日志打印類
│  ├──entryability
│  │  └──EntryAbility.ts           // 程序入口類
│  ├──model
│  │  └──PreferenceModel.ets       // 首選項(xiàng)相關(guān)方法類
│  ├──pages
│  │  └──Index.ets                 // 主界面	
│  ├──view
│  │  ├──ButtonComponent.ets       // 自定義Button組件類
│  │  └──TextItemComponent.ets     // 自定義Text組件類
│  └──viewmodel
│     ├──ButtonItemData.ets        // 按鈕數(shù)據(jù)類
│     └──Fruit.ets                 // 水果數(shù)據(jù)類
└──entry/src/main/resources        // 資源文件目錄

HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿

搜狗高速瀏覽器截圖20240326151547.png

構(gòu)建主界面

在這個(gè)任務(wù)中,我們將完成示例主界面的開(kāi)發(fā),效果圖如下:

從上面效果圖可以看出,主界面主要由2個(gè)相同樣式的文本和文本輸入框,以及3個(gè)相同樣式的按鈕組成。我們可以將文本和文本輸入框抽取成一個(gè)TextItemComponent子組件。再將按鈕抽取成一個(gè)ButtonComponent子組件。

  1. 在ets目錄下,點(diǎn)擊鼠標(biāo)右鍵 > New > Directory,新建名為view的自定義子組件目錄。然后在view目錄下,點(diǎn)擊鼠標(biāo)右鍵 > New > ArkTS File,新建兩個(gè)ArkTS文件,分別為TextItemComponent子組件、ButtonComponent子組件??梢钥吹轿募夸浗Y(jié)構(gòu)如下:
  2. 文本和文本輸入框抽取成的TextItemComponent子組件,效果圖如下:

    具體代碼如下:
    // TextItemComponent.ets
    @Component
    export default struct TextItemComponent {
      private textResource: Resource = $r('app.string.empty'); // 按鈕文本資源
      private placeholderResource: Resource = $r('app.string.empty'); // placeholder文本資源
      private marginBottom: string = '';
      private marginTop: string = '';
      private textInputType: InputType = InputType.Normal; // 輸入框輸入數(shù)據(jù)類型
      private textFlag: number = 0; // 文本框標(biāo)記
      @Link fruit: Fruit; // 水果數(shù)據(jù)
      private textInputCallBack = (value: string) = > {}; // TextInput的回調(diào)
    
      build() {
        Column() {
          Text(this.textResource)
            .fontSize(StyleConstants.TEXT_FONT_SIZE)
            .height(StyleConstants.TEXT_HEIGHT)
            .width(StyleConstants.FULL_PERCENT)
            .fontColor($r('app.color.text_font_color'))
            .letterSpacing(StyleConstants.LETTER_SPACING)
            .fontWeight(StyleConstants.FONT_WEIGHT)
            .margin({
              bottom: StyleConstants.TEXT_MARGIN_BOTTOM,
              left: StyleConstants.TEXT_MARGIN_LEFT,
              top: this.marginTop
            })
    
          TextInput({
            placeholder: this.placeholderResource,
            text: this.textFlag === 0 ? (this.fruit.fruitName) : (this.fruit.fruitNum)
          })
            .placeholderFont({ size: StyleConstants.FONT_SIZE, weight: StyleConstants.FONT_WEIGHT })
            .placeholderColor($r('app.color.placeholder_color'))
            .caretColor(Color.Blue)
            .type(this.textInputType)
            .height(StyleConstants.TEXT_INPUT_HEIGHT)
            .width(StyleConstants.TEXT_INPUT_WIDTH)
            .margin({ bottom: this.marginBottom })
            .fontSize(StyleConstants.FONT_SIZE)
            .fontColor($r('app.color.text_font_color'))
            .fontWeight(StyleConstants.FONT_WEIGHT)
            .backgroundColor($r('app.color.white'))
            .onChange((value: string) = > {
              this.textInputCallBack(value);
            })
        }
      }
    }
    
  3. 抽取的ButtonComponent子組件,效果圖如下:

    具體代碼如下:
    // ButtonComponent.ets
    @Component
    export default struct ButtonComponent {
      private buttonItemValues: Array
    
  4. 在Index.ets主界面中引用TextItemComponent和ButtonComponent子組件,具體代碼如下:
    // Index.ets
    Column() {
      // 水果名稱輸入框
      TextItemComponent({
        textResource: $r('app.string.fruit_text'),
        placeholderResource: $r('app.string.fruit_placeholder'),
        textFlag: CommonConstants.FRUIT_FLAG,
        fruit: $fruit,
        textInputCallBack: (value: string) = > {
          this.fruit.fruitName = value;
        }
      })
    
      // 水果數(shù)量輸入框
      TextItemComponent({
        textResource: $r('app.string.number_text'),
        placeholderResource: $r('app.string.number_placeholder'),
        textFlag: CommonConstants.NUMBER_FLAG,
        fruit: $fruit,
        textInputCallBack: (value: string) = > {
          this.fruit.fruitNum = value;
        }
      })
    
      // 按鈕組件
      ButtonComponent({ fruit: $fruit })
    }
    .width(StyleConstants.FULL_PERCENT)
    .height(StyleConstants.FULL_PERCENT)
    .backgroundColor($r('app.color.main_background_color'))
    

創(chuàng)建數(shù)據(jù)文件

創(chuàng)建數(shù)據(jù)文件需要如下兩個(gè)步驟:

  • 導(dǎo)入dataPreferences模塊。
  • 通過(guò)dataPreferences模塊的getPreferences(context, name)方法獲取到對(duì)應(yīng)文件名的Preferences實(shí)例。

Preferences的數(shù)據(jù)存儲(chǔ)在文件中,因此需要指定存儲(chǔ)的文件名PREFERENCES_NAME。再通過(guò)Preferences提供的方法進(jìn)行數(shù)據(jù)庫(kù)的相關(guān)操作。具體代碼如下:

// PreferenceModel.ets
// 導(dǎo)入dataPreferences模塊
import dataPreferences from '@ohos.data.preferences';

let context = getContext(this);
let preference: dataPreferences.Preferences;
let preferenceTemp: dataPreferences.Preferences;

// 調(diào)用getPreferences方法讀取指定首選項(xiàng)持久化文件,將數(shù)據(jù)加載到Preferences實(shí)例,用于數(shù)據(jù)操作
async getPreferencesFromStorage() {
  try {
    preference = await dataPreferences.getPreferences(context, CommonConstants.PREFERENCES_NAME);
  } catch (err) {
    Logger.error(CommonConstants.TAG, `Failed to get preferences, Cause: ${err}`);
  }
}

寫(xiě)入數(shù)據(jù)

獲取Preferences實(shí)例后,使用Preferences的put方法,將用戶輸入的水果名稱和水果數(shù)量數(shù)據(jù),保存到緩存的實(shí)例中。再通過(guò)Preferences的flush方法將Preferences實(shí)例異步存儲(chǔ)到首選項(xiàng)持久化文件中。具體代碼如下:

// PreferenceModel.ets
async putPreference(fruit: Fruit) {
  ...
  try {
    // 將用戶輸入的水果名稱和水果數(shù)量數(shù)據(jù),保存到緩存的Preference實(shí)例中
    await preference.put(CommonConstants.KEY_NAME, JSON.stringify(fruit));
  } catch (err) {
    Logger.error(CommonConstants.TAG, `Failed to put value, Cause: ${err}`);
  }
  // 將Preference實(shí)例存儲(chǔ)到首選項(xiàng)持久化文件中
  await preference.flush();
}

讀取數(shù)據(jù)

使用Preferences的get方法讀取數(shù)據(jù)。如果鍵不存在,則返回默認(rèn)值。例如獲取下面代碼中fruit的值,如果fruit的鍵KEY_NAME不存在,則會(huì)返回空字符串。通過(guò)默認(rèn)值的設(shè)置,來(lái)避免程序出現(xiàn)異常。具體代碼如下:

// PreferenceModel.ets
async getPreference() {
  let fruit = '';
  ...
  try {
    fruit = (await preference.get(CommonConstants.KEY_NAME, '')).toString();
  } catch (err) {
    Logger.error(CommonConstants.TAG, `Failed to get value, Cause: ${err}`);
  }
  ...
}

刪除數(shù)據(jù)文件

通過(guò)dataPreferences模塊的deletePreferences(context, name)方法從內(nèi)存中移除指定文件對(duì)應(yīng)的Preferences單實(shí)例。移除Preferences單實(shí)例時(shí),應(yīng)用不允許再使用該實(shí)例進(jìn)行數(shù)據(jù)操作,否則會(huì)出現(xiàn)數(shù)據(jù)一致性問(wèn)題。具體代碼如下:

// PreferenceModel.ets
async deletePreferences() {
  try {
    await dataPreferences.deletePreferences(context, CommonConstants.PREFERENCES_NAME);
  } catch(err) {
    Logger.error(CommonConstants.TAG, `Failed to delete preferences, Cause: ${err}`);
  };
  ...
}

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 鴻蒙
    +關(guān)注

    關(guān)注

    57

    文章

    2339

    瀏覽量

    42805
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1973

    瀏覽量

    30143
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3713

    瀏覽量

    16254
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    TL3588-視頻開(kāi)發(fā)案

    TL3588-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 01-24 16:29 ?673次閱讀
    TL3588-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

    鴻蒙OS開(kāi)發(fā)實(shí)例:【工具類封裝-首選項(xiàng)本地存儲(chǔ)】

    **import dataPreferences from '@ohos.data.preferences'; import bundleManager from '@ohos.bundle.bundleManager';** 本地首選項(xiàng)數(shù)據(jù)的保存,利用key val
    的頭像 發(fā)表于 03-28 15:45 ?1722次閱讀
    鴻蒙OS<b class='flag-5'>開(kāi)發(fā)</b>實(shí)例:【工具類封裝-<b class='flag-5'>首選項(xiàng)</b>本地存儲(chǔ)】

    3568F-視頻開(kāi)發(fā)案

    3568F-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 04-12 13:51 ?887次閱讀
    3568F-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

    HarmonyOS開(kāi)發(fā)案例:【用戶首選項(xiàng)

    用戶首選項(xiàng)為應(yīng)用提供Key-Value鍵值型的數(shù)據(jù)處理能力,支持應(yīng)用持久化輕量級(jí)數(shù)據(jù),常用于保存應(yīng)用配置信息、用戶偏好設(shè)置等。本篇Codelab將基于用戶首選項(xiàng)實(shí)現(xiàn)一個(gè)簡(jiǎn)單的數(shù)據(jù)管理應(yīng)用,包含新增、查詢和刪除的功能。
    的頭像 發(fā)表于 04-18 15:34 ?936次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)案</b>例:【用戶<b class='flag-5'>首選項(xiàng)</b>】

    HarmonyOS開(kāi)發(fā)實(shí)例:【手機(jī)備忘錄】

    基于用戶首選項(xiàng),實(shí)現(xiàn)了備忘錄新增、更新、刪除以及查找等功能。
    的頭像 發(fā)表于 04-18 21:40 ?791次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)</b>實(shí)例:【手機(jī)備忘錄】

    如何設(shè)置Xilinx ISE首選項(xiàng)11.x 12.x的默認(rèn)值

    可能是一個(gè)新手問(wèn)題,我們有一個(gè)配置允許不同版本的附加工具,如modelsim,synplicity。我們想知道是否有辦法告訴Xilinx默認(rèn)使用什么。具體來(lái)說(shuō),我們有興趣設(shè)置以下值: 首選項(xiàng)
    發(fā)表于 11-15 11:29

    查看首選項(xiàng)未保存, 如何保存設(shè)置?

    您好,我想把論壇中的帖子看成“平面閱讀模式”而不是“線程閱讀模式”。所以我轉(zhuǎn)到用戶控制面板,編輯配置文件,特性首選項(xiàng),查看首選項(xiàng),并將其設(shè)置為“平面”,然后單擊“保存配置文件”。如果我移動(dòng)到其他
    發(fā)表于 09-11 12:08

    HarmonyOS IoT 硬件開(kāi)發(fā)案例分享

    ``許思維老師HiSpark Wi-Fi IoT 開(kāi)發(fā)案例分享:案例一:AHT20溫濕度傳感器開(kāi)發(fā)、調(diào)試;案例二:oled屏驅(qū)動(dòng)庫(kù)移植,調(diào)試;案例三:用OLED屏播放視頻,Wi-Fi 和 TCP/IP 綜合應(yīng)用。 ``
    發(fā)表于 10-27 17:30

    【潤(rùn)和直播課預(yù)告@華為開(kāi)發(fā)者學(xué)院】HarmonyOS設(shè)備開(kāi)發(fā)基礎(chǔ)課程|HiSpark WiFi-IoT 智能小車套件開(kāi)發(fā)案

    `【潤(rùn)和直播課預(yù)告@華為開(kāi)發(fā)者學(xué)院】HarmonyOS設(shè)備開(kāi)發(fā)基礎(chǔ)課程|HiSparkWiFi-IoT 智能小車套件開(kāi)發(fā)案例,3月18日(周四) 19:00-21:00,讓你的
    發(fā)表于 03-16 15:01

    ESP8266/ARDUINO構(gòu)建H找不到首選項(xiàng)怎么解決?

    大家好!我對(duì)運(yùn)行 Arduino 核心的 ESP32 有一些扎實(shí)的經(jīng)驗(yàn),并且一直在使用首選項(xiàng)庫(kù)來(lái)存儲(chǔ),你猜對(duì)了,首選項(xiàng),到該平臺(tái)上的 NVS。這是一個(gè)簡(jiǎn)單而順利的過(guò)程。我正在嘗試將我的代碼移植到運(yùn)行
    發(fā)表于 02-21 07:44

    許思維老師HarmonyOS IoT硬件開(kāi)發(fā)案例分享

    許思維老師HiSpark Wi-Fi IoT 開(kāi)發(fā)案例分享:案例一:AHT20溫濕度傳感器開(kāi)發(fā)、調(diào)試;案例二:oled屏驅(qū)動(dòng)庫(kù)移植,調(diào)試;案例三:用OLED屏播放視頻,Wi-Fi 和 TCP/IP 綜合應(yīng)用。
    發(fā)表于 10-29 10:39 ?39次下載
    許思維老師<b class='flag-5'>HarmonyOS</b> IoT硬件<b class='flag-5'>開(kāi)發(fā)案</b>例分享

    華為開(kāi)發(fā)者分論壇HarmonyOS學(xué)生公開(kāi)課-OpenHarmony Codelabs開(kāi)發(fā)案

    2021華為開(kāi)發(fā)者分論壇HarmonyOS學(xué)生公開(kāi)課-OpenHarmony Codelabs開(kāi)發(fā)案
    的頭像 發(fā)表于 10-24 11:25 ?1913次閱讀
    華為<b class='flag-5'>開(kāi)發(fā)</b>者分論壇<b class='flag-5'>HarmonyOS</b>學(xué)生公開(kāi)課-OpenHarmony Codelabs<b class='flag-5'>開(kāi)發(fā)案</b>例

    RK3568---NPU開(kāi)發(fā)案

    RK3568---NPU開(kāi)發(fā)案
    的頭像 發(fā)表于 01-19 13:50 ?914次閱讀
    RK3568---NPU<b class='flag-5'>開(kāi)發(fā)案</b>例

    HarmonyOS開(kāi)發(fā)案例:【app初始啟動(dòng)】

    基于自定義彈框、首選項(xiàng)和頁(yè)面路由實(shí)現(xiàn)一個(gè)模擬應(yīng)用首次啟動(dòng)的案例。
    的頭像 發(fā)表于 04-18 22:04 ?414次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)案</b>例:【app初始啟動(dòng)】

    鴻蒙開(kāi)發(fā)接口數(shù)據(jù)管理:【@ohos.data.preferences (首選項(xiàng))】

    首選項(xiàng)為應(yīng)用提供key-value鍵值型的數(shù)據(jù)處理能力,支持應(yīng)用持久化輕量級(jí)數(shù)據(jù),并對(duì)其修改和查詢。數(shù)據(jù)存儲(chǔ)形式為鍵值對(duì),鍵的類型為字符串型,值的存儲(chǔ)數(shù)據(jù)類型包括數(shù)字型、字符型、布爾型。
    的頭像 發(fā)表于 06-10 18:46 ?1617次閱讀
    RM新时代网站-首页