鸿蒙开发加强2

2024-06-02 10:52
文章标签 开发 加强 鸿蒙

本文主要是介绍鸿蒙开发加强2,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

快速创建一个符合长度的数组  空数组
Array.from({length: 200})   // 200的长度的空数组
场景:只确定长度,不确定内容的情况

@State 状态装饰器 =》增强功能
数据变化了 可以引起页面的重新渲染
没有@State修饰的变量,不会引起UI的刷新渲染
加不加@state看数据变化是不是需要重新展示
数据变化后需要重新展示页面的,必须加@State来修饰


创建一个控制器,调用一个函数
将控制器和被控制者绑定
控制器控制行为


control Scroller = new Scroller()
Grid(this.control){}
 this.control.scrollPage({ next: true })  // 下一页
  this.control.scrollPage({ next: false }) // 上一页
  
  
滚动条设置
scrollBar(BarState.枚举)
scrollBarWidth()
scrollBarColor()


和Grid共用一个scroller
滚动条定制
1. 要有一个控制器 两个都设置   => 和Grid产生联动
2. ScrollBar 滚动条组件 自己滚自己


默认是竖着滚动
ScrollBar({scroller:this.control,direction:ScrollBarDirection.Horizontal}){
// 里面的结构

}


$r('app.media.图片名') => $r() 是图片资源地址
'app.media.图片名'  => 是string 图片名

ResourceStr 是Resource和string的联合类型

--------------------------------------------------
Scroll,Tabs

Scroll容器组件
子组件的布局尺寸超过scroll的尺寸

Scroll只支持一个组件
设置滚动方向:
竖向滚动   scrollable(ScrollDirection.Vertical)  默认
横向滚动   scrollable(ScrollDirection.Horizontal)

scrollBar            设置滚动条状态
scrollBarColor       设置滚动条颜色
scrollBarWidth         设置滚动条宽
edgeEffect             设置滚动条边缘效果


Scroll的控制器
scroller: Scroller = new Scroller()

this.scroller.scrollEdge(Edge.Top) // 返回顶部

获取滚动条的距离
this.scroller.currentOffset().xOffset
this.scroller.currentOffset().yOffset

Scroll事件
滚动时添加逻辑   滚动时 一直触发
注册滚动事件 =》添加一个逻辑 指定他的执行时机
.onScroll((x:number,y:number)=>{  })


容器组件Tabs
Tabs(){ 
TabContent(){}.tabBar('')
 }

TabContent 里只能有一个子组件

Tabs 支持两种切换 滑动,点击

通用属性
导航位置
barPosition   Tabs({barPosition:BarPosition.End})
垂直导航 =》车机和平板用的多
.vertical(true)
禁用滑动切换(默认可以滑动切换)
.scrollbale(false)
点击切换(切换时的动画效果)
.animationDuration(数字)
.animationDuration(0)  ==》切换时瞬间切换


滚动导航栏
tabs导航栏一旦多了 默认挤压效果
.barMode(BarMode.Scrollable)


自定义构建函数(自定义结构函数)
Tabs() { TabContent() {}.tabBar(this.fun()) }
@Builder
fun() { }

Tabs组件事件
onChange(event:(index:number)=>void)   在改变时执行  页面切换完成时执行
onTabBarClick(event:(index:number)=>void) 在点击导航栏时执行 只要点击时立即执行

 // 思维导图


这篇关于鸿蒙开发加强2的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1023760

相关文章

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3