HarmonyOS Flex、栅格布局详解 栅格布局一般怎么用
yuyutoo 2024-10-25 19:17 6 浏览 0 评论
一、Flex弹性布局
Flex布局是CSS布局的一种新方式,它可以简化布局过程,让开发者更容易地创建灵活的布局。Flex布局提供了一种灵活的方式来对容器内的项进行排列、对齐和分配空间,它在鸿蒙中同样适用。
1.1 主轴方向
1.1.1 FlexDirection.Row
主轴为水平方向,子组件从起始端沿着水平方向开始排布
1.1.2 FlexDirection.RowReverse
主轴为水平方向,子组件从终点端沿着FlexDirection. Row相反的方向开始排布。
1.1.3 FlexDirection.Column
主轴为垂直方向,子组件从起始端沿着垂直方向开始排布。
1.1.4 FlexDirection.ColumnReverse
主轴为垂直方向,子组件从终点端沿着FlexDirection. Column相反的方向开始排布。
1.2 布局换行
1.2.1 FlexWrap. NoWrap
默认值不换行。如果子组件的宽度总和大于父元素的宽度,则子组件会被压缩宽度
1.2.2 FlexWrap. Wrap
换行,每一行子组件按照主轴方向排列
1.2.3 FlexWrap. WrapReverse
换行,每一行子组件按照主轴反方向排列。
1.3 主轴对齐
1.3.1 FlexAlign.Start
默认值,子组件在主轴方向起始端对齐, 第一个子组件与父元素边沿对齐,其他元素与前一个元素对齐。
1.3.2 FlexAlign.Center
子组件在主轴方向居中对齐
1.3.3 FlexAlign.End
子组件在主轴方向终点端对齐, 最后一个子组件与父元素边沿对齐,其他元素与后一个元素对齐。
1.3.4 FlexAlign.SpaceBetween
Flex主轴方向均匀分配弹性元素,相邻子组件之间距离相同。第一个子组件和最后一个子组件与父元素边沿对齐。
1.3.5 FlexAlign.SpaceAround
Flex主轴方向均匀分配弹性元素,相邻子组件之间距离相同。第一个子组件到主轴起始端的距离和最后一个子组件到主轴终点端的距离是相邻元素之间距离的一半。
1.3.6 FlexAlign.SpaceEvenly
Flex主轴方向元素等间距布局,相邻子组件之间的间距、第一个子组件与主轴起始端的间距、最后一个子组件到主轴终点端的间距均相等。
1.4 交叉轴对齐
1.4.1 容器组件设置交叉轴对齐
1.4.1.1 ItemAlign.Auto
使用Flex容器中默认配置
1.4.1.2 ItemAlign.Start
交叉轴方向首部对齐。
1.4.1.3 ItemAlign.Center
交叉轴方向居中对齐。
1.4.1.4 ItemAlign.End
交叉轴方向底部对齐。
1.4.1.5 ItemAlign.Stretch
交叉轴方向拉伸填充,在未设置尺寸时,拉伸到容器尺寸。
1.4.1.6 ItemAlign. Baseline
交叉轴方向文本基线对齐。
1.4.2 子组件设置交叉轴对齐
子组件的alignSelf属性也可以设置子组件在父容器交叉轴的对齐格式,且会覆盖Flex布局容器中alignItems配置
1.5 自适应拉伸
1.5.1 flexBasis
设置子组件在父容器主轴方向上的基准尺寸。如果设置了该值,则子项占用的空间为设置的值;如果没设置该属性,那子项的空间为width/height的值
1.5.2 flexGrow
设置父容器的剩余空间分配给此属性所在组件的比例。用于“瓜分”父组件的剩余空间。
1.5.3 flexShrink
当父容器空间不足时,子组件的压缩比例
二、栅格布局
栅格布局(Grid Layout)是一种在现代前端开发中广泛使用的布局技术,它允许开发者以二维(行和列)的方式精确地控制网页元素的布局。与传统的流式布局(如float和position)相比,栅格布局提供了更高级的布局控制能力,尤其是在响应式设计和复杂界面布局方面。
2.1 栅格系统断点
栅格系统中的“断点”(Breakpoints)是响应式设计的核心概念之一,主要用于定义在不同屏幕尺寸下,网页布局应如何变化。断点是预设的屏幕宽度阈值,当视口尺寸达到这些阈值时,样式规则会发生变化,从而调整布局以适应不同的设备和屏幕尺寸。
- 栅格系统默认断点将设备宽度分为xs、sm、md、lg四类
- 在GridRow栅格组件中,允许开发者使用breakpoints自定义修改断点的取值范围,最多支持6个断点,除了默认的四个断点外,还可以启用xl,xxl两个断点,支持六种不同尺寸(xs, sm, md, lg, xl, xxl)
2.1.1 启用xs、sm、md
breakpoints: {value: ['100vp', '200vp']}
共3个断点,小于100vp为xs,100vp-200vp为sm,大于200vp为md
2.1.2 启用xs, sm, md, lg, xl, xxl
@State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
...
GridRow({
breakpoints: {
value: ['200vp', '300vp', '400vp', '500vp', '600vp'],
reference: BreakpointsReference.WindowSize
}
}) {
ForEach(this.bgColors, (color, index) => {
GridCol({
span: {
xs: 2, // 在最小宽度类型设备上,栅格子组件占2列。
sm: 3, // 在小宽度类型设备上,栅格子组件占据3列。
md: 4, // 在中等宽度类型设备上,栅格子组件占4列。
lg: 6, // 在大宽度类型设备上,栅格子组件占6列。
xl: 8, // 在特大宽度类型设备上,栅格子组件占8列。
xxl: 12 // 在超大宽度类型设备上,栅格子组件占12列。
}
}) {
Row() {
Text(`${index}`)
}.width("100%").height('50vp')
}.backgroundColor(color)
})
}
2.2 布局
2.2.1 排列
栅格布局中,可以通过设置GridRow的direction属性来指定栅格子组件在栅格容器中的排列方向。该属性可以设置为GridRowDirection.Row(从左往右排列)或GridRowDirection.RowReverse(从右往左排列)
GridRow({ direction: GridRowDirection.Row }){}
2.2.2 间距
子组件间距 GridRow中通过gutter属性设置子元素在水平和垂直方向的间距
GridRow({ gutter: 10 }){}
2.2.3 子组件GridCol
GridCol组件作为GridRow组件的子组件,通过给GridCol传参或者设置属性两种方式,设置span(占用列数),offset(偏移列数),order(元素序号)的值
span:子组件占栅格布局的列数,决定了子组件的宽度,默认为1
GridCol({ span: 2 }){}
2.2.4 偏移
offset: 栅格子组件相对于前一个子组件的偏移列数,默认为0。
GridCol({ offset: 2 }){}
2.2.5 排序
在栅格系统中,order属性通常用于控制元素在容器中的显示顺序。它决定子组件排列次序,当子组件不设置order或者设置相同的order, 子组件按照代码顺序展示;当子组件设置不同的order时,order较小的组件在前,较大的在后。
相关推荐
- ETCD 故障恢复(etc常见故障)
-
概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...
- 在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法
-
FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...
- 如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)
-
---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...
- 使用 Fail Ban 日志分析 SSH 攻击行为
-
通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...
- 《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》
-
服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...
- 聊聊Spring AI Alibaba的YuQueDocumentReader
-
序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...
- Mac Docker环境,利用Canal实现MySQL同步ES
-
Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...
- RustDesk:开源远程控制工具的技术架构与全场景部署实战
-
一、开源远程控制领域的革新者1.1行业痛点与解决方案...
- 长安汽车一代CS75Plus2020款安装高德地图7.5
-
不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...
- Zookeeper使用详解之常见操作篇(zookeeper ui)
-
一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...
- zk源码—4.会话的实现原理一(会话层的基本功能是什么)
-
大纲1.创建会话...
- Zookeeper 可观测性最佳实践(zookeeper能够确保)
-
Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...
- 服务器密码错误被锁定怎么解决(服务器密码错几次锁)
-
#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...
- zk基础—4.zk实现分布式功能(分布式zk的使用)
-
大纲1.zk实现数据发布订阅...
- 《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析
-
在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...
你 发表评论:
欢迎- 一周热门
-
-
前端面试:iframe 的优缺点? iframe有那些缺点
-
带斜线的表头制作好了,如何填充内容?这几种方法你更喜欢哪个?
-
漫学笔记之PHP.ini常用的配置信息
-
其实模版网站在开发工作中很重要,推荐几个参考站给大家
-
推荐7个模板代码和其他游戏源码下载的网址
-
[干货] JAVA - JVM - 2 内存两分 [干货]+java+-+jvm+-+2+内存两分吗
-
正在学习使用python搭建自动化测试框架?这个系统包你可能会用到
-
织梦(Dedecms)建站教程 织梦建站详细步骤
-
【开源分享】2024PHP在线客服系统源码(搭建教程+终身使用)
-
2024PHP在线客服系统源码+完全开源 带详细搭建教程
-
- 最近发表
-
- ETCD 故障恢复(etc常见故障)
- 在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法
- 如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)
- 使用 Fail Ban 日志分析 SSH 攻击行为
- 《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》
- 聊聊Spring AI Alibaba的YuQueDocumentReader
- Mac Docker环境,利用Canal实现MySQL同步ES
- RustDesk:开源远程控制工具的技术架构与全场景部署实战
- 长安汽车一代CS75Plus2020款安装高德地图7.5
- Zookeeper使用详解之常见操作篇(zookeeper ui)
- 标签列表
-
- mybatis plus (70)
- scheduledtask (71)
- css滚动条 (60)
- java学生成绩管理系统 (59)
- 结构体数组 (69)
- databasemetadata (64)
- javastatic (68)
- jsp实用教程 (53)
- fontawesome (57)
- widget开发 (57)
- vb net教程 (62)
- hibernate 教程 (63)
- case语句 (57)
- svn连接 (74)
- directoryindex (69)
- session timeout (58)
- textbox换行 (67)
- extension_dir (64)
- linearlayout (58)
- vba高级教程 (75)
- iframe用法 (58)
- sqlparameter (59)
- trim函数 (59)
- flex布局 (63)
- contextloaderlistener (56)