鸿蒙开发:填充剩余空间

简介: 关于占满剩余的空间,如果权重能够解决,还是以权重为主,因为Blank的使用必须父组件的宽高有值,否则就会不生效,当然了,在实际的开发中,还是具体问题具体分析,使用恰当的方式解决为主。

前言


本文基于Api13。


有两个组件,暂且不论横向纵向,后一个组件需要占满剩下的空间,该如何绘制呢?



肯定有的人都会想起,给后一个组件设置宽度为100%,不就可以了吗?来,我们验证一下,例举一个很简单的案例,使用Row组件,设置两个测试组件,前一个组件宽度为100,后一个宽度设置为100%。


@Entry
@Component
struct DemoPage {
  build() {
    Column() {
      Row() {
        Column()
          .width(100)
          .height("100%")
          .backgroundColor(Color.Red)
        Column()
          .width("100%")
          .height("100%")
          .backgroundColor(Color.Orange)
      }.width("100%")
      .height(50)
    }
    .height('100%')
    .width('100%')
  }
}


运行之后,我们看下效果,还别说,后一个组件还真沾满了剩余的空间。



但是,以上的真的是正确的吗?我们在组件中填充上内容,再次观察一下,随便填充一个组件就可以,这里我用了一个Text组件:


Column(){
          Text("123456789101112131415161718192021222324252627282930")
        }
          .width("100%")
          .height("100%")
          .backgroundColor(Color.Orange)


运行之后,我们看下效果:



想必大家已经看到问题了,如果说后一个组件占满了剩余的空间,文字展示应该在屏幕最后边时进行换行,但偏偏,内容已经超出了屏幕一些后,才进行了换行,也就是说后一个组件其实远远不是剩余空间的宽度,而是整个屏幕的宽度。



百分比


所以,直接给后一个组件设置为100%是不对的,正确的做法是,两个组件都设置百分比,比如给前一个设置20%,后一个设置80%。


Row() {
        Column()
          .width("20%")
          .height("100%")
          .backgroundColor(Color.Red)
        Column(){
          Text("123456789101112131415161718192021222324252627282930")
        }
          .width("80%")
          .height("100%")
          .backgroundColor(Color.Orange)
      }.width("100%")
      .height(50)


运行之后,可以发现,后一个组件确实占满了剩余的空间。



但是问题又来了,我前一个组件如果不是百分比啊,就是固定的宽度,后一个组件如何设置呢?


权重layoutWeight


显然在实际的开发中,前一个固定宽度或者高度的组件大有存在,如何让后一个组件占满剩余的空间,那就需要权重layoutWeight属性了。


Row() {
        Column()
          .width(100)
          .height("100%")
          .backgroundColor(Color.Red)
        Column() {
          Text("123456789101112131415161718192021222324252627282930")
        }
        .layoutWeight(1)
        .height("100%")
        .backgroundColor(Color.Orange)
      }.width("100%")
      .height(50)


可以看到后一个组件完美的占满了剩余的空间。



如果是左右固定,中间的组件占满剩余的空间呢?权重属性依然可以解决。


Row() {
        Column()
          .width(100)
          .height("100%")
          .backgroundColor(Color.Red)
        Column() {
          Text("1234567891011121314151617181920")
        }
        .layoutWeight(1)
        .height("100%")
        .backgroundColor(Color.Orange)
        Column()
          .width(100)
          .height("100%")
          .backgroundColor(Color.Red)
      }.width("100%")
      .height(50)



空白填充Blank


权重是可以解决剩余空间问题,但是有的需求是,两个组件一个居左,一个居右,中间是空白区域,如何摆放组件呢?


这种情况可以使用RelativeContainer组件,让子组件相对父容器居左居右即可。


当然了,还有一种方式,那就是空白填充组件Blank。

Row() {
        Text("组件1")
          .height("100%")
          .backgroundColor(Color.Red)
        Blank()
          .color(Color.Orange)
        Text("组件2")
          .height("100%")
          .backgroundColor(Color.Red)
      }.width("100%")
      .height(50)


运行后看下效果:



相关总结


关于占满剩余的空间,如果权重能够解决,还是以权重为主,因为Blank的使用必须父组件的宽高有值,否则就会不生效,当然了,在实际的开发中,还是具体问题具体分析,使用恰当的方式解决为主。

目录
打赏
0
1
1
0
186
分享
相关文章
鸿蒙开发:了解分割线
在实际的开发中,如果自带的分割线能够满足我们的需求,以自身的分割线属性为主,如果不满足,我们可以使用组件进行绘制。
63 16
鸿蒙开发:了解分割线
鸿蒙开发,远场通信服务rcp拦截器问题
关于rcp的拦截器问题,最重要的就是会话复用的时候,如果Request对象中有需要的参数,就直接用Request中的,而不是使用session中的。
鸿蒙开发,远场通信服务rcp拦截器问题
鸿蒙开发:什么是ArkTs?
本小结主要简单介绍了ArkTs语言的相关知识,都是一些概念性质的内容,大家作为一个了解即可
107 61
一文彻底拿下HarmonyOS NEXT开发实战调试技巧
这是一篇关于HarmonyOS NEXT开发调试技巧的文章,作者是一名经验丰富的程序员Feri。内容涵盖三种调试方法:预览+日志方式(适合简单调试,需注意数据类型转换)、断点调试(详细介绍了设置步骤与功能键使用)以及hilog实战使用(日志打印限制为4096字节,推荐封装维护)。通过这些技巧,帮助开发者更高效地解决问题,提升编程能力。
69 14
一文彻底拿下HarmonyOS NEXT开发实战调试技巧
HarmonyOS Next~鸿蒙应用框架开发实战:Ability Kit与Accessibility Kit深度解析
本书深入解析HarmonyOS应用框架开发,聚焦Ability Kit与Accessibility Kit两大核心组件。Ability Kit通过FA/PA双引擎架构实现跨设备协同,支持分布式能力开发;Accessibility Kit提供无障碍服务构建方案,优化用户体验。内容涵盖设计理念、实践案例、调试优化及未来演进方向,助力开发者打造高效、包容的分布式应用,体现HarmonyOS生态价值。
61 27
HarmonyOS Next~鸿蒙AI功能开发:Core Speech Kit与Core Vision Kit的技术解析与实践
本文深入解析鸿蒙操作系统(HarmonyOS)中的Core Speech Kit与Core Vision Kit,探讨其在AI功能开发中的核心能力与实践方法。Core Speech Kit聚焦语音交互,提供语音识别、合成等功能,支持多场景应用;Core Vision Kit专注视觉处理,涵盖人脸检测、OCR等技术。文章还分析了两者的协同应用及生态发展趋势,展望未来AI技术与鸿蒙系统结合带来的智能交互新阶段。
55 31
|
1天前
|
API
鸿蒙开发:单一手势实现长按事件
虽然说我们可以通过onTouch来实现一个长按事件,但是如果想要实现连续,多指那么就比较麻烦,远远没有LongPressGesture实现起来简单,所以在实际的开发中,大家还是以LongPressGesture为主。
鸿蒙开发:单一手势实现长按事件
|
2天前
鸿蒙开发:单一手势实现多次点击事件
TapGesture点击手势,在实际的开发中,更多的是运用于双击或者需要多次点击的场景,如果仅仅是单次点击,建议大家直接使用onClick即可。
鸿蒙开发:单一手势实现多次点击事件
鸿蒙开发:刷新库V2装饰器适配
如果你是新写的项目,建议直接上手V2装饰器,即便是已经存在的项目,对于新的模块,也是尽量以V2为主。
鸿蒙开发:刷新库V2装饰器适配
|
9天前
|
鸿蒙开发:远场通信服务rcp会话问题
总体来说,问题倒不是很大,解决起来也不是很麻烦,所以啊,老铁们,在实际的开发中,对于一些官方文档,还是建议多看,这样可以提前避免后续的不必要麻烦。
鸿蒙开发:远场通信服务rcp会话问题