<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>
0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

HarmonyOS開發案例:【排行榜頁面】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-04-30 16:16 ? 次閱讀

介紹

本課程使用聲明式語法和組件化基礎知識,搭建一個可刷新的排行榜頁面。在排行榜頁面中,使用循環渲染控制語法來實現列表數據渲染,使用@Builder創建排行列表布局內容,使用裝飾器@State、@Prop、@Link來管理組件狀態。最后我們點擊系統返回按鍵,來學習自定義組件生命周期函數。效果如圖所示:

相關概念

1.渲染控制語法:

  • [條件渲染]:使用if/else進行條件渲染。語法如下:
Column() {
   if (this.count > 0) {
       Text('count is positive')
   }
}
  • [循環渲染]:開發框架提供循環渲染(ForEach組件)來迭代數組,并為每個數組項創建相應的組件。ForEach定義如下:
ForEach(
  arr: any[], // 用于迭代的數組
  itemGenerator: (item: any, index?: number) = > void, // 生成子組件的lambda函數
  keyGenerator?: (item: any, index?: number) = > string // 用于給定數組項生成唯一且穩定的鍵值
)

2.組件狀態管理裝飾器和@Builder裝飾器:

組件狀態管理裝飾器用來管理組件中的狀態,它們分別是:@State、@Prop、@Link。

  • [@State]裝飾的變量是組件內部的狀態數據,當這些狀態數據被修改時,將會調用所在組件的build方法進行UI刷新。
  • [@Prop]與@State有相同的語義,但初始化方式不同。@Prop裝飾的變量必須使用其父組件提供的@State變量進行初始化,允許組件內部修改@Prop變量,但更改不會通知給父組件,即@Prop屬于單向數據綁定。
  • [@Link]裝飾的變量可以和父組件的@State變量建立雙向數據綁定,需要注意的是:@Link變量不能在組件內部進行初始化。
  • [@Builder]裝飾的方法用于定義組件的聲明式UI描述,在一個自定義組件內快速生成多個布局內容。

@State、@Prop、@Link三者關系如圖所示:

3.組件生命周期函數:

[自定義組件的生命周期函數]用于通知用戶該自定義組件的生命周期,這些回調函數是私有的,在運行時由開發框架在特定的時間進行調用,不能從應用程序中手動調用這些回調函數。 右圖是自定義組件生命周期的簡化圖示:

說明: 需要注意的是,部分生命周期回調函數僅對**@Entry**修飾的自定義組件生效,它們分別是:onPageShow、onPageHide、onBackPress。

環境搭建

軟件要求

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

硬件要求

  • 開發板類型:[潤和RK3568開發板]。
  • OpenHarmony系統:3.2 Release。

環境搭建

完成本篇Codelab我們首先要完成開發環境的搭建,本示例以RK3568開發板為例,參照以下步驟進行:

  1. [獲取OpenHarmony系統版本]:標準系統解決方案(二進制)。以3.2 Release版本為例:
  2. 搭建燒錄環境。
    1. [完成DevEco Device Tool的安裝]
    2. [完成RK3568開發板的燒錄]
  3. 搭建開發環境。
    1. 開始前請參考[工具準備],完成DevEco Studio的安裝和開發環境配置。
    2. 開發環境配置完成后,請參考[使用工程向導]創建工程(模板選擇“Empty Ability”)。
    3. 工程創建完成后,選擇使用[真機進行調測]。
    4. 鴻蒙開發指導文檔:[qr23.cn/FBD4cY]

代碼結構解讀

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

├──entry/src/main/ets               // 代碼區    
│  ├──common                        // 公共文件目錄
│  │  └──constants                  
│  │     └──Constants.ets           // 常量
│  ├──entryability
│  │  └──EntryAbility.ts            // 應用的入口
│  ├──model                         
│  │  └──DataModel.ets              // 模擬數據
│  ├──pages
│  │  └──RankPage.ets               // 入口頁面
│  ├──view                          // 自定義組件目錄
│  │  ├──ListHeaderComponent.ets
│  │  ├──ListItemComponent.ets
│  │  └──TitleComponent.ets
│  └──viewmodel         
│     ├──RankData.ets               // 實體類            
│     └──RankViewModel.ets          // 視圖業務邏輯類
└──entry/src/main/resources         // 資源文件目錄

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

使用@Link封裝標題組件

在TitleComponent文件中,首先使用struct對象創建自定義組件,然后使用@Link修飾器管理TitleComponent組件內的狀態變量isRefreshData,狀態變量isRefreshData值發生改變后,通過@Link裝飾器通知頁面刷新List中的數據。代碼如下:

// TitleComponent.ets
...
@Component
export struct TitleComponent {
  @Link isRefreshData: boolean; // 判斷是否刷新數據
  @State title: Resource = $r('app.string.title_default');

  build() {
    Row() {
      ...
      Row() {
        Image($r('app.media.loading'))
          .height(TitleBarStyle.IMAGE_LOADING_SIZE)
          .width(TitleBarStyle.IMAGE_LOADING_SIZE)
          .onClick(() = > {
            this.isRefreshData = !this.isRefreshData;
          })
      }
      .width(TitleBarStyle.WEIGHT)
      .height(WEIGHT)
      .justifyContent(FlexAlign.End)
    }
   ...
  }
}

效果如圖所示:

封裝列表頭部樣式組件

在ListHeaderComponent文件中,我們使用常規成員變量來設置自定義組件ListHeaderComponent的widthValue和paddingValue,代碼如下:

// ListHeaderComponent.ets
...
@Component
export struct ListHeaderComponent {
  paddingValue: Padding | Length = 0;
  widthValue: Length = 0;

  build() {
    Row() {
      Text($r('app.string.page_number'))
        .fontSize(FontSize.SMALL)
        .width(ListHeaderStyle.LAYOUT_WEIGHT_LEFT)
        .fontWeight(ListHeaderStyle.FONT_WEIGHT)
        .fontColor($r('app.color.font_description'))
      Text($r('app.string.page_type'))
        .fontSize(FontSize.SMALL)
        .width(ListHeaderStyle.LAYOUT_WEIGHT_CENTER)
        .fontWeight(ListHeaderStyle.FONT_WEIGHT)
        .fontColor($r('app.color.font_description'))
      Text($r('app.string.page_vote'))
        .fontSize(FontSize.SMALL)
        .width(ListHeaderStyle.LAYOUT_WEIGHT_RIGHT)
        .fontWeight(ListHeaderStyle.FONT_WEIGHT)
        .fontColor($r('app.color.font_description'))
    }
    .width(this.widthValue)
    .padding(this.paddingValue)
  }
}

效果如圖所示:

創建ListItemComponent

為了體現@Prop單向綁定功能,我們在ListItemComponent組件中添加了一個@Prop修飾的字段isSwitchDataSource,當通過點擊改變ListItemComponent組件中isSwitchDataSource狀態時,ListItemComponent作為List的子組件,并不會通知其父組件List刷新狀態。

在代碼中,我們使用@State管理ListItemComponent中的 isChange 狀態,當用戶點擊ListItemComponent時,ListItemComponent組件中的文本顏色發生變化。我們使用條件渲染控制語句,創建的圓型文本組件。

// ListItemComponent.ets
...
@Component
export struct ListItemComponent {
  index?: number;
  private name?: Resource;
  @Prop vote: string = '';
  @Prop isSwitchDataSource: boolean = false;
  // 判斷是否改變ListItemComponent字體顏色
  @State isChange: boolean = false;

  build() {
    Row() {
      Column() {
        if (this.isRenderCircleText()) {
          if (this.index !== undefined) {
            this.CircleText(this.index);
          }
        } else {
          Text(this.index?.toString())
            .lineHeight(ItemStyle.TEXT_LAYOUT_SIZE)
            .textAlign(TextAlign.Center)
            .width(ItemStyle.TEXT_LAYOUT_SIZE)
            .fontWeight(FontWeight.BOLD)
            .fontSize(FontSize.SMALL)
        }
      }
      .width(ItemStyle.LAYOUT_WEIGHT_LEFT)
      .alignItems(HorizontalAlign.Start)

      Text(this.name)
        .width(ItemStyle.LAYOUT_WEIGHT_CENTER)
        .fontWeight(FontWeight.BOLDER)
        .fontSize(FontSize.MIDDLE)
        .fontColor(this.isChange ? ItemStyle.COLOR_BLUE : ItemStyle.COLOR_BLACK)
      Text(this.vote)
        .width(ItemStyle.LAYOUT_WEIGHT_RIGHT)
        .fontWeight(FontWeight.BOLD)
        .fontSize(FontSize.SMALL)
        .fontColor(this.isChange ? ItemStyle.COLOR_BLUE : ItemStyle.COLOR_BLACK)
    }
    .height(ItemStyle.BAR_HEIGHT)
    .width(WEIGHT)
    .onClick(() = > {
      this.isSwitchDataSource = !this.isSwitchDataSource;
      this.isChange = !this.isChange;
    })
  }
  ...
}

效果如圖所示:

創建RankList

為了簡化代碼,提高代碼的可讀性,我們使用@Builder描述排行列表布局內容,使用循環渲染組件ForEach創建ListItem。代碼如下:

// RankPage.ets
...
  build() {
    Column() {
      // 頂部標題組件
      TitleComponent({ isRefreshData: $isSwitchDataSource, title: TITLE })
      // 列表頭部樣式
      ListHeaderComponent({
        paddingValue: {
          left: Style.RANK_PADDING,
          right: Style.RANK_PADDING
        },
        widthValue: Style.CONTENT_WIDTH
      })
      .margin({
        top: Style.HEADER_MARGIN_TOP,
        bottom: Style.HEADER_MARGIN_BOTTOM
      })
      // 列表區域
      this.RankList(Style.CONTENT_WIDTH)
    }
    .backgroundColor($r('app.color.background'))
    .height(WEIGHT)
    .width(WEIGHT)
  }

  @Builder RankList(widthValue: Length) {
    Column() {
      List() {
        ForEach(this.isSwitchDataSource ? this.dataSource1 : this.dataSource2,
          (item: RankData, index?: number) = > {
            ListItem() {
              ListItemComponent({ index: (Number(index) + 1), name: item.name, vote: item.vote,
                isSwitchDataSource: this.isSwitchDataSource
              })
            }
          }, (item: RankData) = > JSON.stringify(item))
      }
      .width(WEIGHT)
      .height(Style.LIST_HEIGHT)
      .divider({ strokeWidth: Style.STROKE_WIDTH })
    }
    .padding({
      left: Style.RANK_PADDING,
      right: Style.RANK_PADDING
    })
    .borderRadius(Style.BORDER_RADIUS)
    .width(widthValue)
    .alignItems(HorizontalAlign.Center)
    .backgroundColor(Color.White)
  }
...

效果如圖所示:

使用自定義組件生命周期函數

我們通過點擊系統導航返回按鈕來演示onBackPress回調方法的使用,在指定的時間段內,如果滿足退出條件,onBackPress將返回false,系統默認關閉當前頁面。否則,提示用戶需要再點擊一次才能退出,同時onBackPress返回true,表示用戶自己處理導航返回事件。代碼如下:

// RankPage.ets
... 
@Entry
@Component
struct RankPage {
  ...
  onBackPress() {
    if (this.isShowToast()) {
      prompt.showToast({
        message: $r('app.string.prompt_text'),
        duration: TIME
      });
      this.clickBackTimeRecord = new Date().getTime();
      return true;
    }
    return false;
  }
  ...
}

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 變量
    +關注

    關注

    0

    文章

    597

    瀏覽量

    28113
  • 鴻蒙
    +關注

    關注

    55

    文章

    1646

    瀏覽量

    42124
  • HarmonyOS
    +關注

    關注

    79

    文章

    1860

    瀏覽量

    29267
  • OpenHarmony
    +關注

    關注

    23

    文章

    3321

    瀏覽量

    15161
  • RK3568
    +關注

    關注

    4

    文章

    435

    瀏覽量

    4142
收藏 人收藏

    評論

    相關推薦

    亞太地區十大半導體供應商排行榜

    亞太地區十大半導體供應商排行榜1.  英特爾(Intel) 2.  三星電子(Samsung Electronics) 3.  德州儀器
    發表于 05-26 14:27

    中國IC設計公司排行榜

    作者:林曉林  中國IC設計公司排行榜:近日,市場調研公司iSuppli出臺了2005年度中國IC設計公司排行榜,與中國半導體協會的排名不同,此次名列榜首的是來自香港的晶門
    發表于 05-26 14:29

    2013年2月份編程軟件排行榜,LabVIEWTop27,進步很大。

    本帖最后由 sushu 于 2013-2-13 10:58 編輯 剛剛上網發現編程軟件排名,關注的LabVIEW現在已經是27位了,小開心一下。TIOBE編程語言社區排行榜是編程語言流行趨勢
    發表于 11-06 12:40

    資料下載總排行榜

    資料下載總排行榜,怎么就那幾個啊,怎么下載到人氣高的資料?資料茫茫,我相信大家的眼睛雪亮的。求方法收集些好的資料。。。
    發表于 03-05 16:24

    各種排行榜匯總貼?。。。?!

    本帖最后由 dongyumin 于 2013-7-31 11:39 編輯 1.2012網上各地年終獎排行榜,科技、電子企業全面領跑!https://bbs.elecfans.com
    發表于 07-30 11:55

    一個都不能死排行榜怎么刷分呢

    一個都不能死排行榜前幾名都是好幾億的分數,簡直太厲害了吧,這個分數要刷多久才能獲得呢?一個都不能死快速刷分攻略教程?其實所謂的刷分并不需要玩家花費多少精力,而是非常輕松的,上次琵琶網小編也有分享了刷
    發表于 05-28 15:24

    2014年4月方案公司出貨量排行榜

    。而其他方案廠商憑借海外市場以及國內中小品牌、中低端市場持續穩扎穩守。2014年4月方案公司出貨量排行榜如下:(更多精彩關注公眾微信號:ittbank)
    發表于 06-23 11:41

    2014年10月 TIOBE 編程語言排行榜發布

    2014年10月的 TIOBE 編程語言排行榜發布了,該版本最大的兩點是 Google 的 Dart 語言首次進入前 20 名。其競爭者包括 CoffeeScript 目前排名 133,TypeScript 排名 122.想知道完整的排名表格請回復
    發表于 12-08 13:46

    小米放出“手機電量排行榜” 為續航神機Max 2造勢

    的4850mAh再進一步提升到300mAh。MIUI官方微博放出了一組小米手機家族的電量排行榜,并向網友征詢:“你覺得小米Max2多大電量夠你用? ”從排行榜來看,現款小米Max以4850mAh的容量
    發表于 05-24 15:41

    小米放出“手機電量排行榜” 為續航神機Max 2造勢

    小米手機家族的電量排行榜,并向網友征詢:“你覺得小米Max2多大電量夠你用? ”從排行榜來看,現款小米Max以4850mAh的容量排名第一,其次是小米MIX(4400mAh)、紅米4(4100mAh
    發表于 06-03 14:20

    MapReduce框架音樂排行榜案例

    Hadoop綜合實戰之MapReduce運算優化——音樂排行榜
    發表于 10-16 12:20

    求職必知獨角獸公司排行榜

    世界第 3 的滴滴裁員,求職必知獨角獸公司排行榜
    發表于 06-18 07:30

    2019年2月編程語言排行榜分享

    2019年2月編程語言排行榜
    發表于 07-14 10:28

    【年度盤點】全民投票,電源技術論壇貢獻排行榜

    此帖將總結盤點2020全年電源技術論壇貢獻排行榜,所有上榜的用戶從資料/問答/經驗/討論TOP5榜單中產生,需要大家在所有候選用戶中進行投票,最終投票結果排行TOP3的用戶獲得相應禮品一份!貢獻
    發表于 01-12 15:04

    2020年最新主板型號排行榜 精選資料推薦

    2020年最新主板型號排行榜2020主板型號天梯圖2020主板選購指南一、Intel、AMD電腦主板的辨別二、主板芯片組級別三、板形四、主板對電腦性能有什么影響在使用電腦的時候,我們有時候會需要更換
    發表于 07-26 06:16
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>