ArkTS 如何适配手机和平板,展示不同的 Tabs 页签
ArkTS(Ark TypeScript)作为HarmonyOS应用开发的主要语言,提供了丰富的组件和接口来适配不同设备,包括手机和平板。在展示不同的Tabs页签以适应手机和平板时,ArkTS主要依赖于布局和组件的灵活性,以及响应式设计的概念。以下是一些关键的步骤和考虑因素:
1. 使用断点系统(Breakpoint System)
HarmonyOS提供了断点系统,允许开发者根据设备的屏幕尺寸来应用不同的样式和布局。通过断点系统,可以识别设备类型(如手机、平板)并据此调整Tabs页签的布局。
- 设置断点:在ArkTS中,可以使用
BreakpointSystem类来注册和监听断点变化。根据设备的屏幕尺寸,可以设置不同的断点,如小屏(手机)、大屏(平板)等。 - 响应断点:根据当前断点,调整Tabs页签的布局属性,如位置(顶部、底部、侧边)、宽度、高度等。
2. 自定义Tabs组件
ArkTS允许开发者自定义Tabs组件,以适应不同的设备类型。
- 设置Tabs属性:使用
Tabs组件时,可以通过barPosition属性设置页签的位置(顶部、底部),通过vertical属性设置页签的排列方向(横向、纵向)。 - 响应式设计:在Tabs组件的
build方法中,可以根据断点系统的返回值动态设置Tabs的属性,以实现响应式设计。
3. 编写条件渲染逻辑
根据设备的屏幕尺寸或断点状态,编写条件渲染逻辑,以决定展示哪种Tabs布局。
- 使用if/else语句:在组件的
build方法中,使用if/else语句或类似的逻辑判断语句,根据断点系统的返回值来渲染不同的Tabs布局。 - 动态样式:使用ArkTS的样式绑定功能,根据设备的屏幕尺寸动态调整Tabs组件的样式属性。
4. 示例代码
以下是一个简化的示例代码,展示了如何使用ArkTS的断点系统和Tabs组件来适配手机和平板。
import { BreakpointSystem, BreakpointConstants } from '@ohos/common';@Entry
@Component
struct TabsDemo {@State currentPageIndex: number = 0;private breakpointSystem: BreakpointSystem = new BreakpointSystem();aboutToAppear() {this.breakpointSystem.register();}aboutToDisappear() {this.breakpointSystem.unregister();}build() {let barPosition = this.breakpointSystem.getCurrentBreakpoint() === BreakpointConstants.BREAKPOINT_LG ?BarPosition.End : BarPosition.Start;Column() {Tabs({ barPosition: barPosition, index: this.currentPageIndex, onChange: (index: number) => {this.currentPageIndex = index;}}) {// 假设有多个TabContent组件TabContent() { /* 第一个页面的内容 */ }.tabBar('第一个标签')TabContent() { /* 第二个页面的内容 */ }.tabBar('第二个标签')// ... 其他TabContent组件}// ... 其他布局元素}}
}
注意:上述代码是一个简化的示例,用于说明如何根据断点系统的返回值来设置Tabs组件的barPosition属性。在实际应用中,可能需要根据具体需求进行更多的自定义和逻辑处理。
5. 断点配置@ohos/common代码
import { mediaquery } from '@kit.ArkUI';
import { BreakpointConstants } from '../constants/BreakpointConstants';declare interface BreakPointTypeOption<T> {sm: Tmd: Tlg: T
}export class BreakPointType<T> {options: BreakPointTypeOption<T>constructor(option: BreakPointTypeOption<T>) {this.options = option;}getValue(currentBreakPoint: string): T {if (this.options.sm !== undefined && currentBreakPoint === 'sm') {return this.options.sm as T;}if (this.options.md && currentBreakPoint === 'md') {return this.options.md as T;} else {return this.options.lg as T;}}
}export class BreakpointSystem {private currentBreakpoint: string = '';private smListener?: mediaquery.MediaQueryListener;private mdListener?: mediaquery.MediaQueryListener;private lgListener?: mediaquery.MediaQueryListener;private updateCurrentBreakpoint(breakpoint: string) {if (this.currentBreakpoint !== breakpoint) {this.currentBreakpoint = breakpoint;AppStorage.set<string>(BreakpointConstants.CURRENT_BREAKPOINT, this.currentBreakpoint);}}private isBreakpointSM = (mediaQueryResult: mediaquery.MediaQueryResult) => {if (mediaQueryResult.matches) {this.updateCurrentBreakpoint(BreakpointConstants.BREAKPOINT_SM);}}private isBreakpointMD = (mediaQueryResult: mediaquery.MediaQueryResult) => {if (mediaQueryResult.matches) {this.updateCurrentBreakpoint(BreakpointConstants.BREAKPOINT_MD);}}private isBreakpointLG = (mediaQueryResult: mediaquery.MediaQueryResult) => {if (mediaQueryResult.matches) {this.updateCurrentBreakpoint(BreakpointConstants.BREAKPOINT_LG);}}public register() {this.smListener = mediaquery.matchMediaSync(BreakpointConstants.RANGE_SM);this.smListener.on('change', this.isBreakpointSM);this.mdListener = mediaquery.matchMediaSync(BreakpointConstants.RANGE_MD);this.mdListener.on('change', this.isBreakpointMD);this.lgListener = mediaquery.matchMediaSync(BreakpointConstants.RANGE_LG);this.lgListener.on('change', this.isBreakpointLG);}public unregister() {this.smListener?.off('change', this.isBreakpointSM);this.mdListener?.off('change', this.isBreakpointMD);this.lgListener?.off('change', this.isBreakpointLG);}
}
6. 测试和优化
- 在不同设备上测试:在开发过程中,应在多种设备和屏幕尺寸上进行测试,以确保Tabs页签在不同设备上的展示效果符合预期。
- 优化性能:注意优化Tabs组件的性能,特别是在包含大量页签或复杂内容时。可以通过懒加载、分页加载等方式来减少初始加载时间和内存消耗。
综上所述,ArkTS通过断点系统、自定义组件和响应式设计等方法来适配手机和平板设备,展示不同的Tabs页签。开发者需要根据具体需求进行灵活配置和优化。
相关文章:
ArkTS 如何适配手机和平板,展示不同的 Tabs 页签
ArkTS(Ark TypeScript)作为HarmonyOS应用开发的主要语言,提供了丰富的组件和接口来适配不同设备,包括手机和平板。在展示不同的Tabs页签以适应手机和平板时,ArkTS主要依赖于布局和组件的灵活性,以及响应式设…...
Docker下载途径
Docker不是Linux自带的,需要我们自己安装 官网:https://www.docker.com/ 安装步骤:https://docs.docker.com/engine/install/centos/ Docker Hub官网(镜像仓库):https://hub.docker.com/ 在线安装docker 先卸载旧的docker s…...
Windows: 如何实现CLIPTokenizer.from_pretrained`本地加载`stable-diffusion-2-1-base`
参考:https://blog.csdn.net/qq_38423499/article/details/137158458 https://github.com/VinAIResearch/Anti-DreamBooth?tabreadme-ov-file 联网下载没有问题: import osos.environ["HF_ENDPOINT"] "https://hf-mirror.com" i…...
MySQL 9从入门到性能优化-慢查询日志
【图书推荐】《MySQL 9从入门到性能优化(视频教学版)》-CSDN博客 《MySQL 9从入门到性能优化(视频教学版)(数据库技术丛书)》(王英英)【摘要 书评 试读】- 京东图书 (jd.com) MySQL9数据库技术_夏天又到了…...
ARM学习(33)英飞凌(infineon)PSOC 6 板子学习
笔者来聊一下psoc62 系列板子的知识 1、PSOC62板子介绍 Psoc6-evaluationkit-062S2 与RT-Thread联合推出的一款32位的双core的板子,基于CortexM4以及CortexM0。 管脚兼容Arduio。板载DAP-Link,可以支持调试以及串口,无需外接2MB的Flash以及…...
华为原生鸿蒙操作系统的发布有何重大意义和影响:
#1024程序员节 | 征文# 一、华为原生鸿蒙操作系统的发布对中国的意义可以从多个层面进行分析: 1. 技术自主创新 鸿蒙操作系统的推出标志着中国在操作系统领域的自主创新能力的提升。过去,中国在高端操作系统方面依赖于外国技术,鸿蒙的发布…...
API 接口:连接生活与商业的数字桥梁
在当今数字化高速发展的时代,API(Application Programming Interface,应用程序编程接口)接口正以前所未有的深度和广度影响着我们的日常生活与商业决策。 一、API 接口在日常生活中的应用 智能出行 地图导航应用通过接入各种交通数…...
IEC101 JAVA开发记录
目录 JAVA Demo 仿真工具 平衡式与非平衡式 帧格式 固定帧格式 可变帧格式 单字节 控制域 主站到子站 子站至主站 位组成 链路地址 应用服务数据单元(ASDU) 类型标识TI 可变结构限定词(VSQ) 传送原因(COT) 信息体元素 带品质描述词的单点信息(SIQ) 带品…...
降压恒压150V供电 负载固定5V 持续0.6A电动车仪表供电芯片SL3150H
一、供电能力 高电压输入:SL3150H具备150V的供电能力,这意味着它可以在电动车的复杂电气环境中稳定工作,无论是面对高电压的输入还是电压波动较大的情况,都能保持稳定的输出。固定输出电压与电流:在输出方面ÿ…...
QT 从ttf文件中读取图标
最近在做项目时,遇到需要显示一些特殊字符的需求,这些特殊字符无法从键盘敲出来,于是乎,发现可以从字体库文件ttf中读取显示。 参考博客:QT 图标字体类IconHelper封装支持Font Awesome 5-CSDN博客 该博客封装的很不错…...
JS动态调用变量
当存在多个变量checkbox1、checkbox2、checkbox3、checkbox4的变量时 -常规调用:if(条件A){this.$refs.checkbox1.check true }if(条件B){this.$refs.checkbox2.check true } 或者使用switch case-动态调用: var result 2 // 在dom渲染完成再给checkbox赋值this.$nextTick…...
django restful API
文章目录 项目地址一、django环境安装以及初识restful1.1 安装python 3.10的虚拟环境1.2 创建django工程文件1.3 创建一个book app1.4 序列化(Django JsonResponse)1.4.1创建一个Models1.4.2 创建django的超级用户admin1.4.3 添加serializers.py生成序列化器1.5 FBV创建视图1…...
在xml 中 不等式 做转义处理的问题
对于这种要做转义处理,<![CDATA[ < ]]>...
python——文件存储与写入path
path方法常常用来访问一个文件所在的地址,然后将地址储存在变量中。然后有不同的方法将文件内容进行处理,还可以将文件进行创建。 from pathlib import Path pathPath(xxxxxxx) 1.文件读取操作 (1)txt文件 常用read_text()读取文件内容, …...
AI 提示词(Prompt)入门 :ChatGPT 4.0 高级功能指南
这段时间 GPT4 多了很多功能,今天主要是增加了 GPTs Store 的介绍和 创建 GPTs 的简单方法,那么我们开始吧,文末有彩蛋。 这里主要讲解如下几个点: 1: ChatGPT 4.0 插件的使用 2:ChatGPT 4.0 高级数据分…...
C++:模板
目录 一.泛型编程 二.模板 函数模板 类模板 一.泛型编程 在C中,支持函数重载,如果我们通过函数重载实现通用的交换函数,写法如下: void Swap(int& left, int& right) {int temp left;left right;ri…...
假如浙江与福建合并为“浙福省”
在中国,很多省份之间的关系颇有“渊源”,例如河南与河北、湖南与湖北、广东与广西等等,他们因一山或一湖之隔,地域相近、文化相通。 但有这么两个省份,省名没有共通之处,文化上也有诸多不同,但…...
AI图片生成3D物体和2D视频提取3D动画
包括AI图片生成3D物体的网站: 第一个为Artefacts.AIhttps://app.artefacts.ai/starter 第二个为 https://3d.csm.ai/ 以下4个的视频教程连接https://www.youtube.com/watch?vmQQCyzTA_F8 第三个为Tripo AI: Tripo AI for Web 第四个为Meshy AI: Meshy - Free …...
Android 应用包名的定义 pm list packages查询的包名
问题 在AndroidManifest和build.gradle其实都有应用包名的定义,有时候发现两者不一样,那么最终编译到软件生效的是哪个呢? 现象 连接设备后,通过adb shell pm list packages 查询应用包名,所列的名称是在build.grad…...
递归相关练习
21. 合并两个有序链表 - 力扣(LeetCode) 重复子问题:将l1的头节点跟l2的头结点比较 得到一个较小的头节点l1 随后继续比较 将l1后面一个节点跟l2第一个节点比较 又得到一个较小的节点 不断下去 递归出口:当l1或者l2为空时候 返回…...
【kafka】Golang实现分布式Masscan任务调度系统
要求: 输出两个程序,一个命令行程序(命令行参数用flag)和一个服务端程序。 命令行程序支持通过命令行参数配置下发IP或IP段、端口、扫描带宽,然后将消息推送到kafka里面。 服务端程序: 从kafka消费者接收…...
基于Flask实现的医疗保险欺诈识别监测模型
基于Flask实现的医疗保险欺诈识别监测模型 项目截图 项目简介 社会医疗保险是国家通过立法形式强制实施,由雇主和个人按一定比例缴纳保险费,建立社会医疗保险基金,支付雇员医疗费用的一种医疗保险制度, 它是促进社会文明和进步的…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
如何为服务器生成TLS证书
TLS(Transport Layer Security)证书是确保网络通信安全的重要手段,它通过加密技术保护传输的数据不被窃听和篡改。在服务器上配置TLS证书,可以使用户通过HTTPS协议安全地访问您的网站。本文将详细介绍如何在服务器上生成一个TLS证…...
【HTTP三个基础问题】
面试官您好!HTTP是超文本传输协议,是互联网上客户端和服务器之间传输超文本数据(比如文字、图片、音频、视频等)的核心协议,当前互联网应用最广泛的版本是HTTP1.1,它基于经典的C/S模型,也就是客…...
在WSL2的Ubuntu镜像中安装Docker
Docker官网链接: https://docs.docker.com/engine/install/ubuntu/ 1、运行以下命令卸载所有冲突的软件包: for pkg in docker.io docker-doc docker-compose docker-compose-v2 podman-docker containerd runc; do sudo apt-get remove $pkg; done2、设置Docker…...
JVM 内存结构 详解
内存结构 运行时数据区: Java虚拟机在运行Java程序过程中管理的内存区域。 程序计数器: 线程私有,程序控制流的指示器,分支、循环、跳转、异常处理、线程恢复等基础功能都依赖这个计数器完成。 每个线程都有一个程序计数…...
【VLNs篇】07:NavRL—在动态环境中学习安全飞行
项目内容论文标题NavRL: 在动态环境中学习安全飞行 (NavRL: Learning Safe Flight in Dynamic Environments)核心问题解决无人机在包含静态和动态障碍物的复杂环境中进行安全、高效自主导航的挑战,克服传统方法和现有强化学习方法的局限性。核心算法基于近端策略优化…...
【JVM面试篇】高频八股汇总——类加载和类加载器
目录 1. 讲一下类加载过程? 2. Java创建对象的过程? 3. 对象的生命周期? 4. 类加载器有哪些? 5. 双亲委派模型的作用(好处)? 6. 讲一下类的加载和双亲委派原则? 7. 双亲委派模…...
Golang——9、反射和文件操作
反射和文件操作 1、反射1.1、reflect.TypeOf()获取任意值的类型对象1.2、reflect.ValueOf()1.3、结构体反射 2、文件操作2.1、os.Open()打开文件2.2、方式一:使用Read()读取文件2.3、方式二:bufio读取文件2.4、方式三:os.ReadFile读取2.5、写…...
