鸿蒙应用示例: flexGrow 与 layoutWeight 布局属性比较

 示例代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
@Entry
@Component
struct Page11 {
  @State message: string = 'Hello World';
 
  build() {
    Column() {
      Row(){
        Text("呵呵").flexGrow(1).backgroundColor(Color.Red)
        Text("呵呵").flexGrow(1).backgroundColor(Color.Blue)
      }
      Flex(){
        Text("呵呵").layoutWeight(1).backgroundColor(Color.Red)
        Text("呵呵").flexGrow(1).backgroundColor(Color.Blue)
      }
      Flex(){
        Text("呵呵").flexGrow(1).backgroundColor(Color.Red)
        Text("呵呵呵呵呵呵呵呵呵呵").flexGrow(1).backgroundColor(Color.Blue)
      }.width('100%')
 
      Flex(){
        Text("呵呵").layoutWeight(1).backgroundColor(Color.Red)
        Text("呵呵呵呵呵呵呵呵呵呵").layoutWeight(1).backgroundColor(Color.Blue)
      }.width('100%')
    }
    .height('100%')
    .width('100%')
  }
}

  

引言

在HarmonyOS的应用开发过程中,我们需要对不同类型的布局属性有所了解,以便更好地组织和管理我们的界面。本文将探讨两种重要的布局属性:flexGrow 和 .layoutWeight,并分析它们之间的区别以及各自的适用场景。

1. 使用场景

flexGrow 是一种Flex容器特有的布局属性,它决定了子元素如何根据剩余空间进行扩展。.layoutWeight 则可以在 Flex、Row 和 Column 等多种容器中使用,更加灵活。

2. 混合使用

如果在非 Flex 容器中同时使用 flexGrow 和 .layoutWeight,则只有 .layoutWeight 起作用。这是因为 flexGrow 只在 Flex 容器中有意义,而 .layoutWeight 的兼容性更强。

3. 分配方式

flexGrow 根据每个子元素的权重分配剩余空间,但会优先保留子元素自身的宽度。例如,在有两个子元素的 Flex 容器中,如果两者都设置了 flexGrow: 1,那么它们将平均分配剩余空间。然而,如果其中某个子元素的内容较长,则实际宽度可能会大于另一个。

相比之下,.layoutWeight 根据每个子元素的权重分配整个组件的宽度。这意味着具有相同权重的子元素将获得相同的宽度,无论其内容长度如何。

4. 推荐使用

由于 .layoutWeight 具有简单直观的宽度分配方式,因此在需要均匀分配空间的情况下,推荐使用此属性。

posted @   zhongcx  阅读(31)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示