第六篇【传奇开心果短博文系列】鸿蒙开发技术点案例示例:ArkUI实现响应式布局_鸿蒙系统响应式ui

49 阅读9分钟

传奇开心果短博文系列

  • 系列短博文目录
    • 鸿蒙开发技术点案例示例短博文系列
  • 短博文目录
    • 一、前言
  • 二、ArkTS的ArkUI实现响应式布局方法介绍
  • 三、helloworld官方示例代码中添加Grid组件来实现响应式布局示例代码
  • 四、helloworld官方示例代码中添加Flex组件来实现响应式布局示例代码
  • 五、helloworld官方示例代码中添加媒体查询来实现响应式布局示例代码
  • 六、helloworld官方示例代码中用响应式断点来实现响应式布局示例代码
  • 七、归纳总结

系列短博文目录

鸿蒙开发技术点案例示例短博文系列

短博文目录

一、前言

在这里插入图片描述在ArkTS中使用ArkUI实现响应式布局有以下几个主要作用:

  1. 提供响应式断点:ArkUI提供了一组预定义的媒体查询断点,使开发者能够根据不同的屏幕尺寸和设备类型来定义不同的样式。这些断点可以在组件样式中使用,以便根据屏幕尺寸自动调整布局和样式。
  2. 快速创建响应式组件:ArkUI提供了一系列响应式布局的组件,如Grid、Row、Column等,可以方便地构建响应式布局。这些组件可以自动根据屏幕尺寸调整布局和样式,简化了响应式布局的开发过程。
  3. 简化样式管理:ArkUI的StyleSheet工具提供了一种便捷的方式来管理组件的样式,包括媒体查询样式。使用StyleSheet.create()方法可以定义和组织样式,并将其应用到组件上,使样式的管理更加清晰和可维护。
  4. 提供响应式工具函数:ArkUI还提供了一些辅助函数和工具类,用于处理响应式布局中的常见需求。例如,可以使用响应式断点工具函数来判断当前屏幕尺寸是否满足某个断点条件,从而动态地控制组件的显示和隐藏。

总而言之,ArkUI在ArkTS中实现响应式布局的作用是简化开发者的工作,提供了一系列方便的工具和组件,使开发者能够更轻松地创建适应不同屏幕尺寸的响应式布局。

二、ArkTS的ArkUI实现响应式布局方法介绍

在这里插入图片描述使用ArkTS的ArkUI实现响应式布局有以下几种方法:

  1. 使用Grid布局:ArkUI提供了Grid组件,可以通过设置不同的网格大小和位置,实现响应式布局。你可以根据屏幕尺寸的变化,自动调整网格的布局。
  2. 使用Flex布局:ArkUI也提供了Flex组件,可以使用弹性盒子模型来实现响应式布局。你可以通过设置不同的弹性属性,如flex-grow、flex-shrink和flex-basis,来控制子元素在容器中的布局。
  3. 使用媒体查询:ArkUI支持媒体查询,可以根据屏幕尺寸的变化,动态地改变组件的样式和布局。你可以在不同的媒体查询中定义不同的样式规则,从而实现响应式布局。
  4. 使用响应式断点:ArkUI提供了一些预定义的响应式断点,可以根据屏幕尺寸的变化,自动切换布局。你可以根据不同的断点,设置不同的样式和布局,从而实现响应式布局。

以上是使用ArkTS的ArkUI实现响应式布局的几种方法,你可以根据具体的需求选择合适的方法来实现响应式布局。

三、helloworld官方示例代码中添加Grid组件来实现响应式布局示例代码

在这里插入图片描述如果您想在helloworld官方示例代码中添加Grid组件来实现响应式布局,可以按照以下方式进行修改:

import { Grid, GridItem } from 'arkui';

// 装饰器,指页面入口。 @Entry // 装饰器,指下面开始自定义组件。 @Component // 自定义组件 struct Index { // 装饰器,指状态变量,字符串类型,并赋初始值为"Hello World"。 @State message: string = "Hello World";

// 构造函数,用于声明UI结构。 build() { return ( {/* 响应式断点的布局配置 /} {/ 内容 */} <Text(this.message) .fontSize(50) .fontWeight(FontWeight.Bold) />

{/* 内容 */} {/* 内容 */} ); } }

在上述修改后的代码中,我们使用了Grid和GridItem组件来实现响应式布局。通过设置GridItem组件的colSpan、rowSpan和breakpoint属性,可以实现在不同断点下的布局。

在GridItem组件中,我们嵌套了Text组件来显示状态变量message的值,并设置了字号和字体粗细。

四、helloworld官方示例代码中添加Flex组件来实现响应式布局示例代码

在这里插入图片描述以下是使用Flex布局改造helloworld官方示例代码来实现响应式布局的正确方式:

import { Flex, Text } from 'arkui';

// 装饰器,指页面入口。 @Entry // 装饰器,指下面开始自定义组件。 @Component // 自定义组件 struct Index { // 装饰器,指状态变量,字符串类型,并赋初始值为"Hello World"。 @State message: string = "Hello World";

// 构造函数,用于声明UI结构。 build() { return ( {/* 响应式断点下的布局 /} <Flex.Item flex={[1, 2]} display={['none', 'block']}> {/ 内容 */} <Text(this.message) .fontSize(50) .fontWeight(FontWeight.Bold) /> </Flex.Item>

<Flex.Item flex={1} display={['block', 'none']}> {/* 内容 */} <Text(this.message) .fontSize(50) .fontWeight(FontWeight.Bold) /> </Flex.Item> ); } }

在上述修改后的代码中,我们使用了Flex组件来实现响应式布局。通过设置Flex组件的direction、justify和align属性,可以控制子元素的排列方向、主轴对齐方式和交叉轴对齐方式。

在本例中,我们将Flex组件的direction设置为"column",表示垂直方向的布局;justify设置为"center",表示在主轴上居中对齐;align设置为"center",表示在交叉轴上居中对齐。

在Flex组件内部,我们使用了两个Flex.Item组件来实现响应式布局。通过设置flex属性和display属性,可以控制在不同断点下的布局。

在第一个Flex.Item组件中,我们设置了flex={[1, 2]}和display={[‘none’, ‘block’]},表示在小屏幕下占据1份空间且隐藏,在大屏幕下占据2份空间且显示。

在第二个Flex.Item组件中,我们设置了flex={1}和display={[‘block’, ‘none’]},表示在小屏幕下占据1份空间且显示,而在大屏幕下隐藏。

五、helloworld官方示例代码中添加媒体查询来实现响应式布局示例代码

在这里插入图片描述以下是使用媒体查询来改造上面示例代码实现响应式布局的示例:

import { Text, StyleSheet } from 'arkui';

// 装饰器,指页面入口。 @Entry // 装饰器,指下面开始自定义组件。 @Component // 自定义组件 struct Index { // 装饰器,指状态变量,字符串类型,并赋初始值为"Hello World"。 @State message: string = "Hello World";

// 构造函数,用于声明UI结构。 build() { return ( {this.message} ); } }

// 媒体查询样式 const styles = StyleSheet.create({ text: { fontSize: 50, fontWeight: 'bold', textAlign: 'center', // 在不同屏幕尺寸下的样式 '@media (max-width: 600px)': { fontSize: 30, }, '@media (min-width: 601px) and (max-width: 1200px)': { fontSize: 40, }, '@media (min-width: 1201px)': { fontSize: 50, }, }, });

在上述代码中,我们使用了arkui库的Text组件来显示状态变量message的值,并设置了字体大小、字体粗细和文本对齐方式。

StyleSheet.create()方法中,我们使用了@media媒体查询来针对不同的屏幕尺寸设置不同的字体大小。例如,当屏幕宽度小于等于600px时,字体大小为30;当屏幕宽度在601px到1200px之间时,字体大小为40;当屏幕宽度大于等于1201px时,字体大小为50。

通过将样式应用到Text组件的style属性上,就可以实现根据屏幕尺寸进行响应式布局。

六、helloworld官方示例代码中用响应式断点来实现响应式布局示例代码

在这里插入图片描述以下是使用响应式断点来改造上述示例代码实现响应式布局的示例:

import { Text, StyleSheet } from 'arkui';

// 自定义组件 struct Index { // 装饰器,指状态变量,字符串类型,并赋初始值为"Hello World"。 @State message: string = "Hello World";

// 构造函数,用于声明UI结构。 build() { return ( {this.message} ); } }

// 响应式断点样式 const styles = StyleSheet.create({ text: {

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

img img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上鸿蒙开发知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取