<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天內不再提示

鴻蒙ArkUI:【編程范式:命令式->聲明式】

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-05-13 16:32 ? 次閱讀

命令式

簡單講就是需要開發用代碼一步一步進行布局,這個過程需要開發全程參與。
開發前請熟悉鴻蒙開發指導文檔:[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

  • Objective-C
ObjectiveC
復制代碼
UIView *cardView = [[UIView alloc] init];
cardView.backgroundColor = [UIColor whiteColor];
cardView.layer.cornerRadius = 16;
cardView.clipsToBounds = YES;
[self.view addSubview:cardView];
[cardView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(16);
    make.right.mas_offset(-16);
    make.height.mas_equalTo(116);
    make.top.mas_equalTo(100);
}];
    
NSString *imgUrl = @"https://ke-image.ljcdn.com//110000-inspection//pc1_nBllrJgGj_1.jpg.280x210.jpg";
UIImageView *imgView = [[UIImageView alloc] init];
imgView.backgroundColor = [UIColor lightGrayColor];
[imgView sd_setImageWithURL:[NSURL URLWithString:imgUrl]];
[cardView addSubview:imgView];
[imgView mas_makeConstraints:^(MASConstraintMaker *make) {
    make.top.bottom.mas_offset(0);
    make.left.mas_equalTo(0);
    make.width.mas_equalTo(107);
}];

UILabel *titleLbl = [[UILabel alloc] init];
titleLbl.font = [UIFont systemFontOfSize:14 weight:UIFontWeightBold];
titleLbl.textColor = [UIColor blackColor];
titleLbl.text = @"萬柳書院新一區 南北向滿五唯一";
[cardView addSubview:titleLbl];
[titleLbl mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(imgView.mas_right).mas_offset(12);
    make.right.mas_offset(-12);
    make.top.mas_equalTo(16);
}];

UILabel *subTitleLbl = [[UILabel alloc] init];
subTitleLbl.textColor = [UIColor blackColor];
subTitleLbl.font = [UIFont systemFontOfSize:12 weight:UIFontWeightRegular];
subTitleLbl.text = @"4室2廳/278.35㎡/南 北/萬柳書院";
[cardView addSubview:subTitleLbl];
[subTitleLbl mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.right.mas_equalTo(titleLbl);
    make.top.mas_equalTo(titleLbl.mas_bottom).mas_offset(8);
}];

UILabel *priceLbl = [[UILabel alloc] init];
priceLbl.font = [UIFont systemFontOfSize:14 weight:UIFontWeightBold];
priceLbl.textColor = [UIColor redColor];
priceLbl.text = @"4238萬";
[cardView addSubview:priceLbl];
[priceLbl mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(titleLbl);
    make.bottom.mas_offset(-16);
}];

UILabel *avgPriceLbl = [[UILabel alloc] init];
avgPriceLbl.textColor = [UIColor lightGrayColor];
avgPriceLbl.font = [UIFont systemFontOfSize:12 weight:UIFontWeightRegular];
avgPriceLbl.text = @"155,445元/平";
[cardView addSubview:avgPriceLbl];
[avgPriceLbl mas_makeConstraints:^(MASConstraintMaker *make) {
    make.left.mas_equalTo(priceLbl.mas_right).mas_offset(2);
    make.right.mas_lessThanOrEqualTo(titleLbl.mas_right);
    make.bottom.mas_equalTo(priceLbl);
}];

聲明式

聲明式則是由開發使用語言描述UI頁面長什么樣子,之后全權交給引擎去做

  1. 對頁面結構進行大的拆解。比如上面卡片分左右兩大部分
  2. 選用合適的容器組件進行頁面描述
  3. 針對拆解出來的每個部分重復上面的兩步,直到無法拆解只能使用基本組件描述為止

比如上面的卡片可以進行如下的拆分

  1. 整體是一個Row容器,分為左右兩大部分,左邊是圖片,右邊是一個Column容器
  2. 右邊Column容器又拆分為兩大部分,上面是標題和描述,下面是價格。兩部分按照space-between布局
  3. 上面的標題和描述作為一個整體,里面拆分成Column的兩個組件
  4. 下面價格可以直接使用系統組件Text

ReactNative

TypeScript
復制代碼
 View
  style={{
    borderRadius: 8,
    marginHorizontal: 16,
    flexDirection: 'row',
    backgroundColor: 'white',
    overflow: 'hidden',
    height: 116,
  }} >
   Image
    source={{
      uri: 'https://ke-image.ljcdn.com//110000-inspection//pc1_nBllrJgGj_1.jpg.280x210.jpg',
    }}
    style={{width: 107, backgroundColor: '#eee'}}
  / >
   View
    style={{
      marginVertical: 16,
      marginHorizontal: 12,
      flex: 1,
      justifyContent: 'space-between',
    }} >
     View >
       Text style={{fontSize: 14, color: '#222', fontWeight: '500'}} >
        萬柳書院新一區 南北向滿五唯一
       /Text >
       Text style={{fontSize: 11, color: '#222', marginTop: 8}} >
        4室2廳/278.35㎡/南 北/萬柳書院
       /Text >
     /View >
     View
      style={{flexDirection: 'row', marginTop: 8, alignItems: 'flex-end'}} >
       Text
        style={{
          fontSize: 17,
          color: '#E62222',
          fontWeight: 'bold',
        }} >
        4238萬
       /Text >
       Text style={{fontSize: 11, color: '#999', marginLeft: 6}} >
        155,445元/平
       /Text >
     /View >
   /View >
 /View >

Flutter

flutter
復制代碼

SwiftUI

swift
復制代碼
HStack(spacing:0) {
    AsyncImage(url: URL(string: "https://ke-image.ljcdn.com//110000-inspection//pc1_nBllrJgGj_1.jpg.280x210.jpg"))
        .frame(width:107)
        .aspectRatio(contentMode: .fill)
        .clipped()

    VStack(alignment: .leading,
           spacing:0) {
        VStack(alignment: .leading,
               spacing:0) {
            Text("萬柳書院新一區 南北向滿五唯一")
                .lineLimit(1)
                .font(.system(size: 14))
                .foregroundColor(.black)
                .fontWeight(.bold)
            Text("4室2廳/278.35㎡/南 北/萬柳書院")
                .lineLimit(1)
                .font(.system(size: 12))
                .foregroundColor(.black)
                .padding(.top, 8)
        }

        Spacer()

        HStack(alignment: .bottom,
               spacing:2) {
            Text("4238萬")
                .font(.system(size: 14))
                .foregroundColor(.red)
                .fontWeight(.bold)
            Text("155,445元/平")
                .font(.system(size: 12))
                .foregroundColor(.secondary)
                .padding(.leading, 2)
        }
    }
           .padding(.vertical, 16)
           .padding(.horizontal, 12)

    Spacer()
}
.frame(height: 116)
.background(.white)
.clipShape(RoundedRectangle(cornerRadius: 8))
.padding(.horizontal, 16)
}

ArkUI

typescript
復制代碼
  Row() {
    Row() {
      Image("https://ke-image.ljcdn.com//110000-inspection//pc1_nBllrJgGj_1.jpg.280x210.jpg")
        .width(107)
        .height("100%")
        .objectFit(ImageFit.Cover)
      Column() {
        Column() {
          Text("柳書院新一區 南北向滿五唯一")
            .fontSize(16)
            .fontColor("#222")
            .maxLines(1)
          Text("4室2廳/278.35㎡/南 北/萬柳書院")
            .fontSize(14)
            .fontColor("#222")
            .maxLines(1)
            .margin({ top: 8 })
        }
        .alignItems(HorizontalAlign.Start)

        Row() {
          Text("4238萬")
            .fontSize(15)
            .fontColor("#E62222") 
            .fontWeight(FontWeight.Bold)
          Text("155,445元/平")
            .fontSize(13)
            .fontColor("#222")
            .margin({ left: 2 })
        }
        .justifyContent(FlexAlign.Start)
        .alignItems(VerticalAlign.Bottom)
      }
      .width("100%")
      .height("100%")
      .padding({ top: 16, bottom: 16, left: 12, right: 12 })
      .alignItems(HorizontalAlign.Start)
      .justifyContent(FlexAlign.SpaceBetween)
    }
    .borderRadius(8)
    .margin({ left: 16, right: 16 })
    .backgroundColor(Color.White)
    .justifyContent(FlexAlign.Start)
    .clip(true)
  }
  .height(116)
  .width("100%")
  
`HarmonyOSOpenHarmony鴻蒙文檔籽料:mau123789是v直接拿`

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

小結

  1. 從上面的例子可以看出來,聲明式語法只需要我們描述UI長什么樣就行。不需要做太多布局計算的工作,讓我們少掉一些頭發
  2. ArkUI和SwiftUI的語法最像,甚至它們的狀態管理也很像,都是提供了狀態綁定和監聽機制來更新UI樣式

審核編輯 黃宇

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

    關注

    0

    文章

    349

    瀏覽量

    40631
  • 代碼
    +關注

    關注

    30

    文章

    4566

    瀏覽量

    66988
  • 鴻蒙
    +關注

    關注

    55

    文章

    1806

    瀏覽量

    42160
收藏 人收藏

    評論

    相關推薦

    鴻蒙:我來了!安卓:那我走?

    (簡稱TS)/JavaScript(簡稱JS)為主要編程語言的聲明UI框架(ArkUI 3.0)。同時,ArkCompiler 3.0增加了對TS/JS語言的支持,HarmonyOS
    發表于 11-05 15:51

    HarmonyOS應用開發-ArkUI聲明UI工程體驗與分享

    聲明UI工程體驗1. 創建工程說明:聲明UI工程目前僅在API7才能使用 選擇 選擇eTS語言 創建完成后,這是該目錄,其中common目錄和model目錄需要自行創建即
    發表于 12-08 10:22

    HarmonyOS應用開發-ArkUI聲明UI頁面布局、跳轉與返回的實現

    頁面跳轉聲明UI范式提供了兩種機制來實現頁面間的跳轉:1. 路由容器組件Navigator,包裝了頁面路由的能力,指定頁面target后,使其包裹的子組件都具有路由能力。2. 路由
    發表于 12-09 11:42

    課程預告丨12月15日官方直播帶你領略ArkUI聲明開發范式之美

    方舟開發框架(ArkUI)的聲明開發范式有什么優勢?Java/JS/eTS(extended TypeScript)三種語言,用哪種語言更好?12月15日 19:00-20:30,H
    發表于 12-10 17:52

    Hello HarmonyOS學習筆記:分布新聞客戶端實戰(JS、eTS)

    開發框架(ArkUI),其中JAVA UI框架是基于Java拓展的命令開發,方舟開發框架是基于JS拓展的類Web開發范式(俗稱響應)或T
    發表于 06-23 20:08

    4天帶你上手HarmonyOS ArkUI開發

    本次HarmonyOS ArkUI入門訓練營課程--健康生活實戰篇,手把手教大家如何制作一個合理膳食的APP前端Demo!課程實戰樣例通過ArkUI聲明UI開發框架實現,只需用幾行簡
    發表于 09-09 14:44

    ArkUI框架,更懂程序員的UI信息語法

    搜索了一下ArkUI有什么優勢。發現很重要的一個原因:ArkUI使用了聲明UI開發框架,同時在UI描述上運用了可以和語言運行時深度結合的自研語言ArkTS。
    發表于 12-14 11:23

    4天帶你上手HarmonyOS ArkUI開發——《HarmonyOS ArkUI入門訓練營之健康生活實戰》

    開發者快速提升技能實力進階。目標學員入門開發者(計算機專業相關)學習鏈接:https://t.elecfans.com/c2241.html訓練營目標通過學習ArkUI入門訓練營課程,了解聲明UI開發
    發表于 01-05 11:49

    HarmonyOS/OpenHarmony應用開發-ArkTS的聲明開發范式

    基于ArkTS的聲明開發范式的方舟開發框架是一套開發極簡、高性能、跨設備應用的UI開發框架,支持開發者高效的構建跨設備應用UI界面?;A能力使用基于ArkTS的聲明
    發表于 01-17 15:09

    HarmonyOS/OpenHarmony應用開發-聲明開發范式組件匯總

    組件是構建頁面的核心,每個組件通過對數據和方法的簡單封裝,實現獨立的可視、可交互功能單元。組件之間相互獨立,隨取隨用,也可以在需求相同的地方重復使用。聲明開發范式目前可供選擇的組件如下表所示。組件
    發表于 01-19 11:14

    2022年HarmonyOS/OpenHarmony生態觀察

    持續基于聲明開發體系和三大理念長期演進,全方面發展鴻蒙應用生態。在整體流程上,華為從設計&amp;gt;開發&
    發表于 01-19 13:10

    ArkUI新能力,助力應用開發更便捷

    捷的全部介紹啦,歡迎大家到HarmonyOS開發者官網下載SDK包體驗。 未來ArkUI框架會持續圍繞競爭力和生態演進,多維度細粒度并發,進一步提升能效比,推出統一的聲明2D&amp
    發表于 02-15 11:40

    OpenHarmony應用開發-ArkUI方舟開發框架簡析

    構建UI,主要基于以下幾點考慮: 開發效率: 聲明開發范式更接近自然語義的編程方式,開發者可以直觀地描述UI,無需關心如何實現UI繪制和渲染,開發高效簡潔。 應用性能: 如下圖所示,
    發表于 04-23 09:35

    鴻蒙ArkUI開發-Tabs組件的使用

    鴻蒙ArkUI開發-Tabs組件的使用
    的頭像 發表于 01-19 16:01 ?538次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>ArkUI</b>開發-Tabs組件的使用

    鴻蒙ArkUI:【從代碼到UI顯示的整體渲染流程】

    方舟開發框架(簡稱ArkUI)是鴻蒙開發的UI框架,提供如下兩種開發范式,我們 **只學聲明式開發范式**
    的頭像 發表于 05-13 16:06 ?120次閱讀
    <b class='flag-5'>鴻蒙</b><b class='flag-5'>ArkUI</b>:【從代碼到UI顯示的整體渲染流程】
    亚洲欧美日韩精品久久_久久精品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>