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ā)案例:【待辦列表】

jf_46214456 ? 來(lái)源:jf_46214456 ? 作者:jf_46214456 ? 2024-05-06 15:22 ? 次閱讀

介紹

使用ArkTS聲明式語(yǔ)法和基礎(chǔ)組件,實(shí)現(xiàn)簡(jiǎn)易待辦列表。效果為點(diǎn)擊某一事項(xiàng),替換標(biāo)簽圖片、虛化文字。效果如圖所示:

相關(guān)概念

  • [ArkTS語(yǔ)法]:ArkTS是HarmonyOS的主要應(yīng)用開(kāi)發(fā)語(yǔ)言。ArkTS基于TypeScript(簡(jiǎn)稱TS)語(yǔ)言擴(kuò)展而來(lái),是TS的超集。
  • [Text組件]:顯示一段文本的組件。
  • [Column組件]:沿垂直方向布局的容器。
  • [Row組件]:沿水平方向布局的容器。

環(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ā)環(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è)]。
    4. 鴻蒙開(kāi)發(fā)指導(dǎo)文檔:[qr23.cn/FBD4cY]

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

本篇Codelab只對(duì)核心代碼進(jìn)行講解,對(duì)于完整代碼,我們會(huì)在gitee中提供。

├──entry/src/main/ets                   // ArkTS代碼區(qū)
│  ├──common
│  │  └──constants
│  │     └──CommonConstants.ets         // 公共常量類
│  ├──entryability
│  │  └──EntryAbility.ts                // 程序入口類
│  ├──pages
│  │  └──ToDoListPage.ets               // 主頁(yè)面
│  ├──view
│  │  └──ToDoItem.ets                   // 自定義單項(xiàng)待辦組件
│  └──viewmodel
│     └──DataModel.ets                  // 列表數(shù)據(jù)獲取文件
└──entry/src/main/resources             // 資源文件目錄

`HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789v直接拿`

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

構(gòu)建主界面

本章節(jié)將介紹應(yīng)用主頁(yè)面的實(shí)現(xiàn),采用Column容器嵌套ForEach完成頁(yè)面整體布局,頁(yè)面分為兩個(gè)部分:

  • 標(biāo)題區(qū):使用Text組件顯示“待辦”標(biāo)題。
  • 數(shù)據(jù)列表:使用ForEach循環(huán)渲染自定義組件ToDoItem。

效果如圖所示:

在工程pages目錄中,選中Index.ets,點(diǎn)擊鼠標(biāo)右鍵 > Refactor > Rename,改名為T(mén)oDoListPage.ets。改名后,在工程entryability目錄下,把EntryAbility.ts文件中windowStage.loadContent方法的第一個(gè)參數(shù)修改為pages/ToDoListPage。

// EntryAbility.ts
onWindowStageCreate(windowStage: Window.WindowStage) {
  ...
  windowStage.loadContent('pages/ToDoListPage', (err, data) = > {
    ...
  });
}

選中工程的ets目錄,點(diǎn)擊鼠標(biāo)右鍵 > new > Directory,新建view文件夾。選中新建的view文件夾,點(diǎn)擊鼠標(biāo)右鍵 > new > ArkTS File,新建ToDoItem.ets文件。后續(xù)在此文件中封裝自定義組件。在ToDoListPage.ets中導(dǎo)入封裝的自定義組件ToDoItem,在aboutToAppear生命周期中初始化待辦數(shù)據(jù)totalTasks,在build方法中編寫(xiě)主頁(yè)面布局,使用Text文本組件顯示標(biāo)題,使用ForEach循環(huán)渲染自定義組件ToDoItem。

// ToDoListPage.ets
import ToDoItem'../view/ToDoItem';
...
@Entry
@Component
struct ToDoListPage {
  private totalTasks: Array< string > = [];

  aboutToAppear() {
    this.totalTasks = DataModel.getData();
  }

  build() {
    Column({ space: CommonConstants.COLUMN_SPACE }) {
      Text($r('app.string.page_title'))
        ...
      ForEach(this.totalTasks, (item: string) = > {
        ToDoItem({ content: item })
      }, (item: string) = > JSON.stringify(item))
    }
    ...
  }
}

自定義子組件

在ToDoItem.ets文件中,顯示的文本內(nèi)容為入?yún)ontent,使用@State修飾參數(shù)isComplete來(lái)管理當(dāng)前事項(xiàng)的完成狀態(tài)。當(dāng)點(diǎn)擊當(dāng)前ToDoItem時(shí),觸發(fā)Row組件的onClick事件,更新isComplete的值,isComplete的改變將會(huì)刷新使用該狀態(tài)變量的UI組件。具體表現(xiàn)為:當(dāng)前點(diǎn)擊的ToDoItem中,labelIcon圖片的替換、文本透明度opacity屬性的變化、文本裝飾線decoration的顯隱。

// ToDoItem.ets
...
@Component
export default struct ToDoItem {
  private content: string = '';
  @State isComplete: boolean = false;
  
 @Builder labelIcon(icon: Resource) {
    Image(icon)
      ...
  }

  build() {
    Row() {
      if (this.isComplete) {
        this.labelIcon($r('app.media.ic_ok'));
      } else {
        this.labelIcon($r('app.media.ic_default'));
      }
      Text(this.content)
        ...
        .opacity(this.isComplete ? CommonConstants.OPACITY_COMPLETED : CommonConstants.OPACITY_DEFAULT)
        .decoration({ type: this.isComplete ? TextDecorationType.LineThrough : TextDecorationType.None })
    }
    ...
    .onClick(() = > {
      this.isComplete = !this.isComplete;
    })
  }
}

審核編輯 黃宇

聲明:本文內(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)投訴
  • 開(kāi)發(fā)板
    +關(guān)注

    關(guān)注

    25

    文章

    4834

    瀏覽量

    96821
  • 鴻蒙
    +關(guān)注

    關(guān)注

    57

    文章

    2287

    瀏覽量

    42629
  • HarmonyOS
    +關(guān)注

    關(guān)注

    79

    文章

    1954

    瀏覽量

    29897
  • OpenHarmony
    +關(guān)注

    關(guān)注

    25

    文章

    3607

    瀏覽量

    15956
收藏 人收藏

    評(píng)論

    相關(guān)推薦

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

    TL3588-NPU開(kāi)發(fā)案
    的頭像 發(fā)表于 01-24 15:22 ?530次閱讀
    TL3588-NPU<b class='flag-5'>開(kāi)發(fā)案</b>例

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

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

    TLT507-Linux-RT應(yīng)用開(kāi)發(fā)案

    TLT507-Linux-RT應(yīng)用開(kāi)發(fā)案
    的頭像 發(fā)表于 01-26 09:46 ?620次閱讀
    TLT507-Linux-RT應(yīng)用<b class='flag-5'>開(kāi)發(fā)案</b>例

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

    TLT507-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 01-26 10:50 ?936次閱讀
    TLT507-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

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

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

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

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

    HarmonyOS應(yīng)用開(kāi)發(fā)-UI設(shè)計(jì)開(kāi)發(fā)與預(yù)覽

    `. 介紹通過(guò)智能表待辦應(yīng)用開(kāi)發(fā),讓開(kāi)發(fā)者了解智能表HarmonyOS應(yīng)用開(kāi)發(fā)的全流程,實(shí)現(xiàn)從工程創(chuàng)建到界面預(yù)覽全過(guò)程。使用HUAWEIDe
    發(fā)表于 09-23 17:51

    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

    許思維老師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 ?1851次閱讀
    華為<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>例

    構(gòu)建低功耗數(shù)字化的Wi-Fi待辦事項(xiàng)列表

    電子發(fā)燒友網(wǎng)站提供《構(gòu)建低功耗數(shù)字化的Wi-Fi待辦事項(xiàng)列表.zip》資料免費(fèi)下載
    發(fā)表于 12-23 16:03 ?0次下載
    構(gòu)建低功耗數(shù)字化的Wi-Fi<b class='flag-5'>待辦</b>事項(xiàng)<b class='flag-5'>列表</b>

    OpenHarmony上實(shí)現(xiàn)待辦事項(xiàng)功能

    列表的編輯模式用途十分廣泛,常見(jiàn)于待辦事項(xiàng)管理、文件管理、備忘錄的記錄管理等應(yīng)用場(chǎng)景。
    的頭像 發(fā)表于 06-25 15:19 ?631次閱讀

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

    RK3568-視頻開(kāi)發(fā)案
    的頭像 發(fā)表于 01-18 15:51 ?698次閱讀
    RK3568-視頻<b class='flag-5'>開(kāi)發(fā)案</b>例

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

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