背景
加深對@Observed@ObjectLink 裝飾器使用的理解,以小故事做注釋
效果
代碼片段
這是一個故事
Boss為了交付兩個完全一樣的客戶項目【只要寫1萬行代碼】,在公司內(nèi)部,把一個程序員配給了項目經(jīng)理,讓其監(jiān)督寫代碼
項目經(jīng)理領到指示后, 先告知客戶一,公司為其配了專職程序員,由其隨時發(fā)號施令讓其敲代碼,然后又以同樣的話術(shù)告知客戶二
接下來的事情,客戶一和客戶二,他們都非常滿意,因為每一天,雖然他們各自只督促程序員寫了一行代碼,但每天下班時,
客戶們都能看到兩行代碼,呵呵。Boss聽聞此事,甚是開心,遂告知項目經(jīng)理,也要在每天中督促一次程序員,果不其然,程序員竟然每天可以寫三行代碼了,
對此老板深思了一會......, 做了一個決定,將項目中的程序直接換掉, 僅留當前的項目經(jīng)理.
later,客戶發(fā)現(xiàn)之前寫的代碼沒了,哭天罵娘神明英武的Boss一氣之下,為客戶們重新配了新的項目經(jīng)理和新的程序員
@Entry
@Component
struct Boss{
@State projectManager: ProjectManager = new ProjectManager(new Programmer(0, '小哥1'), '項管1');
build(){
Column({space: 50}){
Customer({ label: '客戶一', programmer: this.projectManager.programmer })
Customer({ label: '客戶二', programmer: this.projectManager.programmer })
Button(`this.projectManager.programmer.codelines+= 1`)
.onClick(() = > {
//Boss告知項目經(jīng)理督促程序員寫代碼
this.projectManager.programmer.codelines += 1;
})
Button(`this.projectManager.programmer = new Programmer(0)`)
.onClick(() = > {
//換程序員
this.projectManager.programmer = new Programmer(0, '小哥2');
})
Button(`this.projectManager = new ProjectManager(Programmer(0))`)
.onClick(() = > {
//換項目經(jīng)理,換程序員
this.projectManager = new ProjectManager(new Programmer(0, '小哥3'), '項管2');
})
}
.width('100%')
.height('100%')
.padding({top: px2vp(111)})
.alignItems(HorizontalAlign.Center)
.justifyContent(FlexAlign.Center)
.backgroundColor(Color.Pink)
}
}
@Observed
class Programmer {
public name: string
public codelines: number = 1;
constructor(c: number, d: string) {
this.codelines = c;
this.name = d;
}
}
class ProjectManager {
public name: string
public programmer: Programmer;
constructor(a: Programmer, b: string) {
this.programmer = a;
this.name = b;
}
}
@Component
struct Customer {
label: string = 'customer';
@ObjectLink programmer: Programmer;
build() {
Row() {
Button(`[${this.label}] 讓 ${this.programmer.name} 寫代碼 = ${this.programmer.codelines}`)
.onClick(() = > {
this.programmer.codelines += 1;
})
}.backgroundColor(Color.Green).padding('16vp')
}
}
審核編輯 黃宇
-
代碼
+關(guān)注
關(guān)注
30文章
4899瀏覽量
70658 -
鴻蒙OS
+關(guān)注
關(guān)注
0文章
191瀏覽量
4981
發(fā)布評論請先 登錄
鴻蒙OS開發(fā)實例:【頁面?zhèn)髦堤D(zhuǎn)】

Harmony 鴻蒙頁面級變量的狀態(tài)管理
鴻蒙OS應用程序開發(fā)
【中秋國慶不斷更】OpenHarmony嵌套類對象屬性變化:@Observed裝飾器和@ObjectLink裝飾器
鴻蒙 OS 應用開發(fā)初體驗
鴻蒙OS系統(tǒng)詳解
鴻蒙OS 2.0手機開發(fā)者Beta版發(fā)布會在京舉辦
華為發(fā)布鴻蒙OS Beta版
鴻蒙OS與Lite OS的區(qū)別是什么
鴻蒙os怎么升級
華為開發(fā)者大會2021鴻蒙os在哪場
鴻蒙OS開發(fā)實例:【裝飾器-@BuilderParam】
鴻蒙OS開發(fā)教學:【編程之重器-裝飾器】

鴻蒙OS開發(fā)實例:【ArkTS類庫多線程@Concurrent裝飾器校驗并發(fā)函數(shù)】

評論