国产chinesehdxxxx老太婆,办公室玩弄爆乳女秘hd,扒开腿狂躁女人爽出白浆 ,丁香婷婷激情俺也去俺来也,ww国产内射精品后入国产

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-18 15:34 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

介紹

用戶首選項(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)用,包含新增、查詢和刪除的功能。效果如圖所示:

相關(guān)概念

  • [dialog]:自定義彈窗容器。
  • [用戶首選項(xiàng)]:用戶首選項(xiàng)為應(yīng)用提供Key-Value鍵值型的數(shù)據(jù)處理能力,支持應(yīng)用持久化輕量級(jí)數(shù)據(jù),并對(duì)其修改和查詢。

環(huán)境搭建

軟件要求

  • [DevEco Studio]版本:DevEco Studio 3.1 Release及以上版本。
  • OpenHarmony SDK版本:API version 9及以上版本。
  • 鴻蒙開(kāi)發(fā)文檔參考:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

硬件要求

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

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

環(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ā)環(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)行講解,對(duì)于完整代碼,我們會(huì)在gitee中提供。

├──entry/src/main/js	              // 代碼區(qū)
│  └──MainAbility
│     ├──common
│     │  ├──constants
│     │  │  └──commonConstants.js     // 公共常量
│     │  ├──database
│     │  │  └──preference.js          // 首選項(xiàng)數(shù)據(jù)處理
│     │  ├──images                    // 圖片圖標(biāo)
│     │  │  ├──ic_delete.png
│     │  │  └──ic_no_data.png
│     │  └──utils	
│     │     └──logger.js              // 日志工具
│     ├──i18n		                  // 國(guó)際化
│     │  ├──en-US.json			
│     │  └──zh-CN.json			
│     └──pages
│        └──index
│           ├──index.css              // 首頁(yè)樣式文件	
│           ├──index.hml              // 首頁(yè)布局文件
│           └──index.js               // 首頁(yè)腳本文件
└──entry/src/main/resources           // 應(yīng)用資源目錄

構(gòu)建界面

應(yīng)用主界面由上至下分為四部分:頂部標(biāo)題欄、搜索欄、數(shù)據(jù)展示區(qū)域、底部按鈕區(qū)域。

每個(gè)區(qū)域都位于div容器組件中,通過(guò)對(duì)容器位置的控制,做好頁(yè)面整體布局。

  • 標(biāo)題欄區(qū)域內(nèi)僅包含text組件,用于設(shè)置標(biāo)題顯示內(nèi)容。
  • 搜索欄區(qū)域內(nèi)僅包含search組件,用于設(shè)置搜索框的顯示。
  • 數(shù)據(jù)展示區(qū)域會(huì)根據(jù)不同場(chǎng)景呈現(xiàn)不同內(nèi)容:無(wú)數(shù)據(jù)時(shí),使用image組件展示“暫無(wú)數(shù)據(jù)”圖片;存在數(shù)據(jù)時(shí),則會(huì)使用list組件展示數(shù)據(jù)列表。
  • 按鈕區(qū)域使用button組件,設(shè)置“清空”和“添加”按鈕。
< !-- index.hml -- >
< div class="container" >
    < !-- 標(biāo)題欄 -- >
    < div class="title-container" >
        < text class="title" >DataBase< /text >
    < /div >
    < !-- 搜索欄 -- >
    < div class="search-container" >
        < search class="search-bar" hint="{{ $t('strings.search_key') }}" searchbutton="{{ $t('strings.search') }}"
                @submit="searchByKey" >< /search >
    < /div >
    < !-- 數(shù)據(jù)區(qū)域(無(wú)數(shù)據(jù)) -- >
    < div class="no-data-container" if="{{ isNoData }}" >
        < image src='/common/images/ic_no_data.png' >< /image >
    < /div >
    < !-- 數(shù)據(jù)區(qū)域(有數(shù)據(jù)) -- >
    < list class="data-container" if="{{ ! isNoData }}" scrollbar="auto" >
        < list-item for="{{ allDataArray }}" class="list-item" >
            < div class="card-container" >
                < div class="text-container" >
                    < text class="key-text" >{{ $item.key }}< /text >
                    < text class="value-text" >{{ $item.value }}< /text >
                < /div >
                < image class="delete-img" src="/common/images/ic_delete.png" @click="deleteData({{ $item.key }})" >
                < /image >
            < /div >
        < /list-item >
    < /list >
    < !-- 按鈕區(qū)域 -- >
    < div class="button-container" >
        < button class="remove" type="capsule" value="{{ $t('strings.delete_all') }}" @click="removeAll" >< /button >
        < button class="add" type="capsule" value="{{ $t('strings.add') }}" @click="addData" >< /button >
    < /div >
< /div >

當(dāng)進(jìn)行添加、刪除、清空等操作,會(huì)彈出對(duì)應(yīng)的對(duì)話框。對(duì)話框使用dialog自定義彈框容器組件,根據(jù)對(duì)話框需要展示的內(nèi)容選擇不同的元素。

< !-- index.hml -- >
< div class="container" >
    < !-- 添加對(duì)話框 -- >
    < dialog id="addDialog" class="add-dialog" >
        < div class="add-dialog-container" >
            < div class="add-input-container" >
                < text class="add-dialog-title" >{{ $t('strings.add') }}< /text >
                < input id="dataKey" class="add-dialog-input" placeholder="{{ $t('strings.key_input') }}"
                       @change="keyChange" >< /input >
                < input id="dataValue" class="add-dialog-input" placeholder="{{ $t('strings.value_input') }}"
                       @change="dataChange" >< /input >
            < /div >
            < div class="add-button-container" >
                < button type="capsule" value="{{ $t('strings.cancel') }}" onclick="addCancel" class="normal-button" >
                < /button >
                < button type="capsule" value="{{ $t('strings.confirm') }}" onclick="addConfirm" class="normal-button" >
                < /button >
            < /div >
        < /div >
    < /dialog >
    < !-- 刪除對(duì)話框 -- >	
    < dialog id="deleteDialog" class="delete-dialog" >
        < div class="delete-dialog-container" >
            < text >{{ $t('strings.delete_hint') }}< /text >
            < div class="delete-button-container" >
                < button type="capsule" value="{{ $t('strings.cancel') }}" onclick="deleteCancel" class="normal-button" >
                < /button >
                < button type="capsule" value="{{ $t('strings.delete') }}" onclick="deleteConfirm" class="delete-button" >
                < /button >
            < /div >
        < /div >
    < /dialog >
    < !-- 清空對(duì)話框 -- >	
    < dialog id="clearDialog" class="delete-dialog" >
        < div class="delete-dialog-container" >
            < text >{{ $t('strings.delete_all_hint') }}< /text >
            < div class="delete-button-container" >
                < button type="capsule" value="{{ $t('strings.cancel') }}" onclick="clearCancel" class="normal-button" >
                < /button >
                < button type="capsule" value="{{ $t('strings.delete_all') }}" onclick="clearConfirm"
                        class="delete-button" >< /button >
            < /div >
        < /div >
    < /dialog >
< /div >

使用用戶首選項(xiàng)

使用用戶首選項(xiàng),需要先導(dǎo)入對(duì)應(yīng)模塊,并獲取Preferences實(shí)例。

// preference.js
import dataPreferences from '@ohos.data.preferences';

let preference = null;

class Preference {
  ...
  async initPreferences() {
    try {
      let context = featureAbility.getContext();
      preference = await dataPreferences.getPreferences(context, CommonConstants.PREFERENCES_NAME);
    } catch (err) {
      logger.error(`Failed to get preferences. code: ${err.code},message: ${err.message}`);
    }
  }
  ...
}

使用put()方法寫(xiě)入需要添加的數(shù)據(jù)。使用flush()方法,將用戶首選項(xiàng)實(shí)例緩存數(shù)據(jù)持久化到對(duì)應(yīng)文件中。

// preference.js
import dataPreferences from '@ohos.data.preferences';

let preference = null;

class Preference {
  ...
  async addData(key, value) {
    ...
    try {
      await preference.put(key, value);
      await preference.flush();
    } catch (err) {
      logger.error(`Fail to add data. code: ${err.code},message: ${err.message}`);
    }
  }
  ...
}

使用getAll()方法查詢所有key值,再根據(jù)所有key值查詢對(duì)應(yīng)value值。

// preference.js
import dataPreferences from '@ohos.data.preferences';

let preference = null;

class Preference {
  ...
  async getAllData() {
    let allData = [];
    ...
    try {
      let value = await preference.getAll();
      let allKeys = Object.keys(value);
      let keyNum = allKeys.length;
      for (let i = 0; i < keyNum; i++) {
        let dataObj = await this.getDataByKey(allKeys[i]);
        allData.push(dataObj);
      }
    } catch (err) {
      logger.error(`Failed to query all data. code: ${err.code},message: ${err.message}`)
    }
    return allData;
  }
  ...
}

使用delete()方法刪除指定鍵值對(duì),使用clear()方法清除此Preferences實(shí)例中的所有數(shù)據(jù)。

// preference.js
import dataPreferences from '@ohos.data.preferences';

let preference = null;

class Preference {
  ...
  async deleteData(key) {
    ...
    try {
      await preference.delete(key);
      await preference.flush();
    } catch (err) {
      logger.error(`Failed to delete. code: ${err.code},message: ${err.message}`);
    }
  }

  async clearData() {
    ...
    try {
      await preference.clear();
      await preference.flush();
    } catch (err) {
      logger.error(`Failed to clear. code: ${err.code},message: ${err.message}`);
    }
  }  
  ...
}

審核編輯 黃宇

聲明:本文內(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)注

    60

    文章

    2617

    瀏覽量

    44022
  • HarmonyOS
    +關(guān)注

    關(guān)注

    80

    文章

    2126

    瀏覽量

    32960
  • OpenHarmony
    +關(guān)注

    關(guān)注

    29

    文章

    3851

    瀏覽量

    18566
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    鴻蒙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 ?2318次閱讀
    鴻蒙OS<b class='flag-5'>開(kāi)發(fā)</b>實(shí)例:【工具類封裝-<b class='flag-5'>首選項(xiàng)</b>本地存儲(chǔ)】

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

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

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

    基于HarmonyOS首選項(xiàng)能力實(shí)現(xiàn)的一個(gè)簡(jiǎn)單示例。
    的頭像 發(fā)表于 04-19 16:20 ?1762次閱讀
    <b class='flag-5'>HarmonyOS</b><b class='flag-5'>開(kāi)發(fā)案</b>例:【<b class='flag-5'>首選項(xiàng)</b>】

    如何設(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 智能小車(chē)套件開(kāi)發(fā)案

    `【潤(rùn)和直播課預(yù)告@華為開(kāi)發(fā)者學(xué)院】HarmonyOS設(shè)備開(kāi)發(fā)基礎(chǔ)課程|HiSparkWiFi-IoT 智能小車(chē)套件開(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數(shù)據(jù)管理與應(yīng)用數(shù)據(jù)持久化(一)

    等。 HarmonyOS標(biāo)準(zhǔn)系統(tǒng)支持典型的存儲(chǔ)數(shù)據(jù)形態(tài),包括用戶首選項(xiàng)、鍵值型數(shù)據(jù)庫(kù)、關(guān)系型數(shù)據(jù)庫(kù)。 開(kāi)發(fā)者可以根據(jù)如下功能介紹,選擇合適的數(shù)據(jù)形態(tài)以滿足自己應(yīng)用數(shù)據(jù)的持久化需要。 ●
    發(fā)表于 11-01 16:27

    華為開(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 ?2165次閱讀
    華為<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>例

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

    基于自定義彈框、首選項(xiàng)和頁(yè)面路由實(shí)現(xiàn)一個(gè)模擬應(yīng)用首次啟動(dòng)的案例。
    的頭像 發(fā)表于 04-18 22:04 ?790次閱讀
    <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 ?2452次閱讀

    華為發(fā)布鴻蒙HarmonyOS 5.0.2 Release

    ,針對(duì)2in1與平板設(shè)備,新增支持自定義應(yīng)用啟動(dòng)時(shí)的啟動(dòng)頁(yè)。ArkData新增flushSync接口,支持將緩存的Preferences實(shí)例中的數(shù)據(jù)存儲(chǔ)到共享用戶首選項(xiàng)的持久化文件中。 ArkGraphics
    的頭像 發(fā)表于 01-23 16:17 ?1580次閱讀

    harmony OS NEXT-通過(guò)用戶首選項(xiàng)實(shí)現(xiàn)數(shù)據(jù)持久化

    # 鴻蒙通過(guò)用戶首選項(xiàng)實(shí)現(xiàn)數(shù)據(jù)持久化 ## 1.1 場(chǎng)景介紹 用戶首選項(xiàng)為應(yīng)用提供Key-Value鍵值型的數(shù)據(jù)處理能力,支持應(yīng)用持久化輕量級(jí)數(shù)據(jù),并對(duì)其修改和查詢。當(dāng)
    的頭像 發(fā)表于 04-29 16:38 ?536次閱讀

    harmony-utils之PreferencesUtil,首選項(xiàng)工具類

    ,借助眾多實(shí)用工具類,致力于助力開(kāi)發(fā)者迅速構(gòu)建鴻蒙應(yīng)用。其封裝的工具涵蓋了APP、設(shè)備、屏幕、授權(quán)、通知、線程間通信、彈框、吐司、生物認(rèn)證、用戶首選項(xiàng)、拍照、相冊(cè)、掃碼、文件、日志,異常捕獲、字符、字符串
    的頭像 發(fā)表于 07-03 11:42 ?105次閱讀