成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

2020征文-手機圖解鴻蒙列表組件ListContainer

系統
文章由鴻蒙社區產出,想要了解更多內容請前往:51CTO和華為官方戰略合作共建的鴻蒙技術社區https://harmonyos.51cto.com/#zz

[[360076]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

一、什么是ListContainer

ListContainer是用來呈現連續、多行數據的列表組件,包含一系列相同類型的列表項。如下圖所示:


二、ListContainer的架構視圖

ListContainer的架構視圖如下所示:

ListContainer作為列表,其中的列表項數據是由適配器Adapter提供的,適配器Adapter作為ListContainer和數據源之間的中介&橋梁,將數據源中的數據映射到要展示的ListContainer中,ListContainer負責以列表的形式顯示適配器Adapter提供的數據。

三、ListContainer的使用步驟

ListContainer的使用步驟主要包括:

1、創建ListContainer

2、創建列表項的布局

3、使用POJO類封裝數據源中與每個列表項對應的數據

4、構造數據源

5、構造適配器Adapter

6、將數據源關聯到適配器Adapter

7、將適配器Adapter應用到ListContainer

四、ListContainer的使用示例

示例的運行效果如下圖所示:

開發步驟如下:

1、創建ListContainer(ability_main.xml)

  1. xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  2.  
  3. ohos:id="$+id:list_container" 
  4.  
  5. ohos:height="match_parent" 
  6.  
  7. ohos:width="match_parent"/> 

 2、創建列表項的布局(item.xml)

  1. xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  2.  
  3. ohos:height="match_content" 
  4.  
  5. ohos:width="match_parent" 
  6.  
  7. ohos:orientation="vertical"
  8.  
  9.  
  10. ohos:id="$+id:name" 
  11.  
  12. ohos:height="50vp" 
  13.  
  14. ohos:width="match_parent" 
  15.  
  16. ohos:padding="5vp" 
  17.  
  18. ohos:auto_font_size="true" 
  19.  
  20. ohos:text_alignment="center"/> 
  21.  
  22.  
  23. ohos:height="1vp" 
  24.  
  25. ohos:width="match_parent" 
  26.  
  27. ohos:background_element="#CCCCCC"/> 

 3、使用POJO類封裝數據源中與每個列表項對應的數據(Item.java)

POJO類指的是:只包含屬性和相應的getter和setter,而沒有業務邏輯的類。

  1. public class Item { 
  2.  
  3. private String name
  4.  
  5. public Item(String name) { 
  6.  
  7. this.name = name
  8.  
  9.  
  10. public String getName() { 
  11.  
  12. return name
  13.  
  14.  
  15. public void setName(String name) { 
  16.  
  17. this.name = name
  18.  
  19.  

 4、構造數據源(MainAbilitySlice.java) 

  1. public class MainAbilitySlice extends AbilitySlice { 
  2.  
  3. @Override 
  4.  
  5. public void onStart(Intent intent) { 
  6.  
  7. super.onStart(intent); 
  8.  
  9. super.setUIContent(ResourceTable.Layout_ability_main); 
  10.  
  11. List list = getData(); 
  12.  
  13.  
  14. private List getData() { 
  15.  
  16. List list = new ArrayList<>(); 
  17.  
  18. for (int i = 1; i <= 100; i++) { 
  19.  
  20. list.add(new Item("Item " + i)); 
  21.  
  22.  
  23. return list; 
  24.  
  25.  

 5、構造適配器Adapter(MyItemProvider.java)

常用的適配器類是RecycleItemProvider,繼承該類時需要重寫四個方法:getCount()、getItem()、getItemId()和getComponent()。其中,對于方法getComponent(),當某個列表項從不可見變為可見時會自動調用該方法,在該方法中適配器Adapter會從數據源取數據,并將返回的數據封裝在一個Component對象中,以便將該對象返回給ListContainer,從而將數據映射到對應的列表項。

  1. public class MyItemProvider extends RecycleItemProvider { 
  2.  
  3. private List list; 
  4.  
  5. private AbilitySlice slice; 
  6.  
  7. public MyItemProvider(List list, AbilitySlice slice) { 
  8.  
  9. this.list = list; 
  10.  
  11. this.slice = slice; 
  12.  
  13.  
  14. @Override 
  15.  
  16. public int getCount() { 
  17.  
  18. return list.size(); 
  19.  
  20.  
  21. @Override 
  22.  
  23. public Object getItem(int position) { 
  24.  
  25. return list.get(position); 
  26.  
  27.  
  28. @Override 
  29.  
  30. public long getItemId(int position) { 
  31.  
  32. return position; 
  33.  
  34.  
  35. @Override 
  36.  
  37. public Component getComponent(int position, Component convertComponent, ComponentContainer componentContainer) { 
  38.  
  39. convertComponent = LayoutScatter.getInstance(slice) 
  40.  
  41. .parse(ResourceTable.Layout_item, nullfalse); 
  42.  
  43. Text text = (Text) convertComponent.findComponentById(ResourceTable.Id_name); 
  44.  
  45. text.setText(list.get(position).getName()); 
  46.  
  47. return convertComponent; 
  48.  
  49.  

 6、將數據源關聯到適配器Adapter(MainAbilitySlice.java) 

  1. public class MainAbilitySlice extends AbilitySlice { 
  2.  
  3. @Override 
  4.  
  5. public void onStart(Intent intent) { 
  6.  
  7. ...... 
  8.  
  9. List list = getData(); 
  10.  
  11. MyItemProvider myItemProvider = new MyItemProvider(list, this); 
  12.  
  13.  
  14. ...... 
  15.  

 7、將適配器Adapter應用到ListContainer(MainAbilitySlice.java) 

  1. public class MainAbilitySlice extends AbilitySlice { 
  2.  
  3. @Override 
  4.  
  5. public void onStart(Intent intent) { 
  6.  
  7. ...... 
  8.  
  9. MyItemProvider myItemProvider = new MyItemProvider(list, this); 
  10.  
  11. ListContainer listContainer = (ListContainer) findComponentById(ResourceTable.Id_list_container); 
  12.  
  13. listContainer.setItemProvider(myItemProvider); 
  14.  
  15.  
  16. ...... 
  17.  

 五、適配器Adapter的優化

對于上面的第5步,當某個列表項從不可見變為可見時,對于自動調用的方法getComponent(),我們是根據列表項的布局文件item.xml創建了一個列表項的實例。這樣的做法性能較差。因為系統會對變為不可見的列表項實例進行緩存,所以對于方法getComponent()中的第二個參數convertComponent有可能不為null。當convertComponent不為null時,說明系統把緩存中的某個列表項實例傳遞過來了,因此,完全可以復用該列表項實例,而沒有必要重新創建一個列表項實例。優化方式如下:

  1. public class MyItemProvider extends RecycleItemProvider { 
  2.  
  3. ...... 
  4.  
  5. @Override 
  6.  
  7. public Component getComponent(int position, Component convertComponent, ComponentContainer componentContainer) { 
  8.  
  9. if (convertComponent == null) { 
  10.  
  11. convertComponent = LayoutScatter.getInstance(slice) 
  12.  
  13. .parse(ResourceTable.Layout_item, nullfalse); 
  14.  
  15.  
  16. Text text = (Text) convertComponent.findComponentById(ResourceTable.Id_name); 
  17.  
  18. text.setText(list.get(position).getName()); 
  19.  
  20. return convertComponent; 
  21.  
  22.  

 六、使用ViewHolder對適配器Adapter做終極優化

在上面的代碼中,得到列表項實例后(不管是新創建的列表項實例,還是從緩存中獲得的列表項實例),都要調用方法findComponentById()以獲得列表項中的子組件。調用方法findComponentById()是比較耗費性能的,所以好的做法是:在新創建列表項實例時,就調用方法findComponentById()以獲得列表項中的所有子組件,并且將所有子組件通過ViewHolder綁定到列表項實例。這樣,當從緩存中獲得列表項實例后,就無需再調用方法findComponentById()了,直接獲得列表項實例綁定的ViewHolder就可以得到所有子組件了。優化方式如下:

  1. public class MyItemProvider extends RecycleItemProvider { 
  2.  
  3. ...... 
  4.  
  5. @Override 
  6.  
  7. public Component getComponent(int position, Component convertComponent, ComponentContainer componentContainer) { 
  8.  
  9. ViewHolder viewHolder; 
  10.  
  11. if (convertComponent == null) { 
  12.  
  13. convertComponent = LayoutScatter.getInstance(slice) 
  14.  
  15. .parse(ResourceTable.Layout_item, nullfalse); 
  16.  
  17. viewHolder = new ViewHolder(); 
  18.  
  19. viewHolder.text = (Text) convertComponent.findComponentById(ResourceTable.Id_name); 
  20.  
  21. convertComponent.setTag(viewHolder); 
  22.  
  23. else { 
  24.  
  25. viewHolder = (ViewHolder) convertComponent.getTag(); 
  26.  
  27.  
  28. viewHolder.text.setText(list.get(position).getName()); 
  29.  
  30. return convertComponent; 
  31.  
  32.  
  33. class ViewHolder { 
  34.  
  35. Text text; 
  36.  
  37.  

 如果你理解了為什么要這么優化,相信你會發現:當列表項中只有一個子組件時,也可以不引入ViewHolder,而是將這個子組件直接綁定到列表項實例。代碼如下所示:

  1. public class MyItemProvider extends RecycleItemProvider { 
  2.  
  3. ...... 
  4.  
  5. @Override 
  6.  
  7. public Component getComponent(int position, Component convertComponent, ComponentContainer componentContainer) { 
  8.  
  9. Text text; 
  10.  
  11. if (convertComponent == null) { 
  12.  
  13. convertComponent = LayoutScatter.getInstance(slice) 
  14.  
  15. .parse(ResourceTable.Layout_item, nullfalse); 
  16.  
  17. text = (Text) convertComponent.findComponentById(ResourceTable.Id_name); 
  18.  
  19. convertComponent.setTag(text); 
  20.  
  21. else { 
  22.  
  23. text = (Text) convertComponent.getTag(); 
  24.  
  25.  
  26. text.setText(list.get(position).getName()); 
  27.  
  28. return convertComponent; 
  29.  
  30.  

 示例源代碼,請見附件。

歡迎訂閱我的專欄【圖解鴻蒙】:

https://harmonyos.51cto.com/column/27

©著作權歸作者和HarmonyOS技術社區共同所有,如需轉載,請注明出處,否則將追究法律責任

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com/#zz

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-08-12 14:59:15

鴻蒙HarmonyOS應用

2020-12-22 11:09:20

鴻蒙Feature AbiAbilitySlic

2020-12-28 11:19:06

鴻蒙HarmonyOSPage Abilit

2020-12-04 12:42:59

組件鴻蒙Text

2020-12-23 11:36:23

鴻蒙HarmonyOS應用程序開發

2020-12-22 09:48:18

鴻蒙HarmonyOS應用程序

2020-12-23 11:24:34

鴻蒙開發IDE安裝

2020-12-22 11:20:36

鴻蒙HarmonyOS游戲

2020-12-23 11:45:27

鴻蒙HarmonyOSTextField組件

2020-12-28 11:30:07

鴻蒙HarmonyOS分布式

2020-12-09 11:53:24

鴻蒙開發HelloWord

2020-12-24 11:24:31

鴻蒙開發JS

2020-12-24 10:05:54

鴻蒙鴻蒙開發Hello World

2020-12-25 10:39:53

鴻蒙開發JS

2021-08-25 09:49:48

鴻蒙HarmonyOS應用

2020-12-29 09:59:01

鴻蒙HarmonyOS智能家居

2022-04-24 15:17:56

鴻蒙操作系統

2020-12-14 09:58:28

鴻蒙HarmonyOS手表游戲

2020-12-11 12:27:35

鴻蒙HarmonyOS

2020-12-16 10:05:48

鴻蒙開發板Onenet平臺
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品美女www爽爽爽视频 | 青青草国产在线观看 | 免费观看色 | 欧美 日本 国产 | 精品久久一区二区三区 | 国产精品一区二区在线免费观看 | 精品自拍视频 | 成人在线小视频 | 国产精品久久久乱弄 | 久久国产成人 | 在线播放亚洲 | 久草在线 | 国产精品一区二区三区在线 | 天堂va在线 | 欧美三级电影在线播放 | 777777777亚洲妇女| 成人黄色a | 韩国成人在线视频 | 久久久免费少妇高潮毛片 | 人妖av| 黄色毛片一级 | 日日操夜夜摸 | 国产情侣在线看 | 一级在线观看 | 亚洲在线高清 | 精品国产伦一区二区三区观看方式 | 国产亚洲欧美在线视频 | www.久久久久久久久久久 | 久在线视频 | 国产黄色在线 | 日韩不卡在线观看 | 国产1区2区在线观看 | 欧美aaaaa | 亚洲一区二区三区四区视频 | www.五月天婷婷 | 一区二视频 | 日本视频免费 | 日韩精品一区二区三区在线观看 | 国内在线视频 | 伊人二区| 一级黄色毛片 |