自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

HarmonyOS DataBinding 使用指南

開(kāi)發(fā) 前端 OpenHarmony
Databinding 顧名思義就是數(shù)據(jù)綁定,HarmonyOS為提供了Databinding庫(kù),該庫(kù)允許你使用聲明格式而不是以代碼的方式將數(shù)據(jù)綁定到UI上。

[[413224]]

想了解更多內(nèi)容,請(qǐng)?jiān)L問(wèn):

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

在開(kāi)始講DataBinding之前,我們不得不先說(shuō)一下MVVM架構(gòu)模式,MVVM是MVP模式的改進(jìn)版,Model層跟View層與MVP模式類似,ViewModel層只做和邏輯處理相關(guān)的工作,在ViewModel中不會(huì)持有View層的引用,這時(shí)候就需要借助DataBinding,通過(guò)Binding方式通信,只需要在ViewModel層對(duì)數(shù)據(jù)進(jìn)行操作,View層就會(huì)自動(dòng)更新UI。

概述

​ Databinding 顧名思義就是數(shù)據(jù)綁定,HarmonyOS為提供了Databinding庫(kù),該庫(kù)允許你使用聲明格式而不是以代碼的方式將數(shù)據(jù)綁定到UI上。Databinding庫(kù)會(huì)解析布局文件,自動(dòng)生成數(shù)據(jù)綁定代碼,實(shí)現(xiàn)數(shù)據(jù)源與UI組件之間的相互綁定。

​ 自動(dòng)生成綁定代碼的基類,是用來(lái)實(shí)現(xiàn)ComponentContainer和ActiveData對(duì)象之間的綁定,ComponentContainer是指組件容器,相當(dāng)于Android的ViewGroup,ActiveData是一個(gè)可觀察數(shù)據(jù)類,同時(shí)也具有生命周期感知,作用類似于Android的LiveData。

​ 當(dāng)ComponentContainer或ActiveData對(duì)象被修改時(shí),DataBinding對(duì)象會(huì)自動(dòng)修改綁定到ComponentContainer或ActiveData的對(duì)象。比如,如果你修改了某個(gè)ComponentContainer的屬性,DataBinding會(huì)將屬性值到綁定到該ComponentContainer的ActiveData對(duì)象。反之亦然,如果一個(gè)ActiveData對(duì)象的屬性值被更改,綁定的ComponentContainer的屬性值也將被更新。

開(kāi)始使用

1.在使用DataBinding之前,首先要在應(yīng)用模塊下build.gradle中開(kāi)啟dataBinding,代碼如下:

  1. ohos { 
  2.     ... 
  3.     buildTypes { 
  4.         debug { 
  5.             dataBindingEnabled true 
  6.         } 
  7.     } 

 2.使用DataBinding之前,首先使用ActiveData對(duì)象來(lái)定義要觀察的數(shù)據(jù),并實(shí)現(xiàn)其0get() 和set()方法:

創(chuàng)建一個(gè)Model類

  1. public class MainAbilityModel { 
  2.     private ActiveData titile; 
  3.  
  4.     public ActiveData getTitile() { 
  5.         return titile; 
  6.     } 
  7.     public void setTitile(ActiveData titile) { 
  8.         this.titile = titile; 
  9.     } 

 3.在我們的布局文件中,聲明DataBinding的綁定標(biāo)簽,并在中定義剛創(chuàng)建的ActiveData Model類。

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <DirectionalLayout 
  3.     xmlns:ohos="http://schemas.huawei.com/res/ohos" 
  4.     ohos:height="match_parent" 
  5.     ohos:width="match_parent" 
  6.     ohos:background_element="#1a1a1a" 
  7.     ohos:orientation="vertical"
  8.  
  9.     <Text 
  10.         ohos:id="$+id:title_text" 
  11.         ohos:height="300" 
  12.         ohos:width="match_parent" 
  13.         ohos:text="${model.titile}" 
  14.         ohos:text_alignment="center" 
  15.         ohos:text_color="#FF555555" 
  16.         ohos:text_size="50"/> 
  17.     <....> 
  18.     <binddata> 
  19.         <variable 
  20.             class="com.example.time.model.MainAbilityModel" 
  21.             name="model"/> 
  22.     </binddata> 
  23. </DirectionalLayout> 

在<Text>的ohos:text屬性,進(jìn)行數(shù)據(jù)綁定ohos:text=“${model.titile}”

4.在布局中聲明DataBinding后,系統(tǒng)會(huì)在編譯后自動(dòng)生成一個(gè)以布局文件命名的Binding類,比如我的布局文件名為ability_main,那么系統(tǒng)就會(huì)自動(dòng)生成一個(gè)AbilityMainBinding類。我們?cè)赟lice類中調(diào)用DataBindingUtil.createBinding方法來(lái)獲取AbilityMainBinding的對(duì)象,然后調(diào)用initComponent及setLifecycle來(lái)初始化對(duì)象,之后我們就可以調(diào)用在ActiveData對(duì)象設(shè)置數(shù)據(jù),調(diào)用MainAbilityModel中定義的方法,綁定到其中的ActiveData對(duì)象。

  1. public class MainAbilitySlice extends AbilitySlice { 
  2.     private static HiLogLabel mLabel = new HiLogLabel(HiLog.LOG_APP, 00001, "suisui"); 
  3.     AbilityMainBinding binding; 
  4.  
  5.     @Override 
  6.     public void onStart(Intent intent) { 
  7.         super.onStart(intent); 
  8.         ComponentContainer componentContainer = 
  9.                 (ComponentContainer) LayoutScatter.getInstance(this).parse(ResourceTable.Layout_ability_main, nullfalse); 
  10.         if (!(componentContainer instanceof ComponentContainer)) { 
  11.             return
  12.         } 
  13.         super.setUIContent(componentContainer); 
  14.         try { 
  15.             binding = DataBindingUtil.createBinding(ResourceTable.Layout_ability_main, getContext(), "com.example.time"); 
  16.         } catch (IllegalArgumentException | IOException exception) { 
  17.             HiLog.info(mLabel, exception.toString()); 
  18.         } 
  19.         if (binding != null) { 
  20.             binding.initComponent(componentContainer); 
  21.             binding.setLifecycle(getLifecycle()); 
  22.             ActiveData price = new ActiveData<>(); 
  23.             price.setData("DataBinding Demo"); 
  24.             MainAbilityModel model = new MainAbilityModel(); 
  25.             model.setTitile(price); 
  26.             binding.setModel(model); 
  27.         } 
  28.     } 

需要注意的是在調(diào)用DataBindingUtil.createBinding時(shí),要替換成自己的包名。

至此,我們大致的把DataBinding的簡(jiǎn)單使用梳理了,總體來(lái)說(shuō)DataBinding可以為我們減少代碼量,也不需要再做findComponentById,設(shè)置數(shù)據(jù)等一些繁瑣的操作。但在實(shí)際業(yè)務(wù)開(kāi)發(fā)當(dāng)中可能也會(huì)有一定的局限性,例如ActiveData的類型轉(zhuǎn)換問(wèn)題,相信后續(xù)官方也會(huì)越來(lái)越完善,HarmonyOS也會(huì)越來(lái)越好,讓我們拭目以待。

最終效果

【中軟國(guó)際】HarmonyOS DataBinding 使用指南-鴻蒙HarmonyOS技術(shù)社區(qū)

注:DevEco Studio版本過(guò)低可能會(huì)導(dǎo)致編譯生成Binding找不到包,可升級(jí)版本再試。

想了解更多內(nèi)容,請(qǐng)?jiān)L問(wèn):

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來(lái)源: 鴻蒙社區(qū)
相關(guān)推薦

2022-09-29 09:07:08

DataGrip數(shù)據(jù)倉(cāng)庫(kù)數(shù)據(jù)庫(kù)

2012-12-26 12:41:14

Android開(kāi)發(fā)WebView

2010-09-06 14:24:28

ppp authent

2011-07-21 14:57:34

jQuery Mobi

2009-12-28 17:40:10

WPF TextBox

2009-12-31 17:17:45

Silverlight

2021-01-12 15:19:23

Kubernetes

2017-01-04 15:22:57

TrimPath模板引擎

2010-06-03 17:27:36

Hadoop命令

2010-08-04 15:37:31

Flex圖表

2010-08-05 15:40:21

FlexBuilder

2010-08-04 14:28:01

Flex組件

2019-11-13 12:39:26

Python 開(kāi)發(fā)編程語(yǔ)言

2024-02-04 00:00:00

Loki性能查詢

2022-06-23 08:01:36

FlaskSocketIOSwift

2009-11-30 13:15:27

PHP模板Smarty

2024-02-18 12:44:22

2011-03-16 10:17:06

2010-12-12 11:27:00

PGP使用指南

2010-02-06 16:30:25

C++內(nèi)存對(duì)齊
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)