鸿蒙开发加强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) 在点击导航栏时执行 只要点击时立即执行

 // 思维导图


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/21083.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

php获取今天凌晨零点的时间

不废话直接上代码 //使用strtotime $midnightToday strtotime("today midnight"); //输出:1716998400 //如果是明天 $midnightToday 86400 //后天 $midnightToday 86400*2//ORM中比对使用 $row ModelVisit::where(uid,$this->uid)->where(visi…

C++面试十二连问(语言基础篇)

前言: C开发讲究的是细分领域,越往后越没有人在意你是不是了解语言特性,但是对相关行业经验的要求就越高。作为初入行业的新人,在经验这块是比较欠缺的,相比之下,C八股还是比较容易上手的,属于努…

学习整理 docker

nexus 搭建nexus将其他pom、jar导入到nexus中

java 比Scanner 更高效的输入输出 BufferedWriter和`OutputStreamWriter

BufferedWriter bw new BufferedWriter(new OutputStreamWriter(System.out)); 当我们在 Java 中需要进行字符输出时,可以使用 BufferedWriter 和 OutputStreamWriter 的组合来实现。下面提供更多相关信息: BufferedWriter: BufferedWriter…

硬件接口介绍(一)常用接口及其测试

目录 一、引言 二、常用接口 ------>2.1、DIMM ------>2.2、DCIN ------>2.3、SDIO 三、以太网 ------>3.1、PHY ------>3.2、MAC ------>3.3、LAN 四、MIPI ------>4.1、MIPI CSI ------>4.2、MIPI DSI 五、HDMI 六、音频 ------>6…

fintuning chatglm3

chatglm3介绍 ChatGLM3-6B 是 ChatGLM 系列最新一代的开源模型,在保留了前两代模型对话流畅、部署门槛低等众多优秀特性的基础上,ChatGLM3-6B 引入了如下特性: 更强大的基础模型: ChatGLM3-6B 的基础模型 ChatGLM3-6B-Base 采用…

ic基础|时钟篇06:crg到底是什么?一文带你了解crg中的时钟系统!

大家好,我是数字小熊饼干,一个练习时长两年半的ic打工人。我在两年前通过自学跨行社招加入了IC行业。现在我打算将这两年的工作经验和当初面试时最常问的一些问题进行总结,并通过汇总成文章的形式进行输出,相信无论你是在职的还是…

Material Design 风格的 UI 框架 Vuetify 使用初体验

不知道国外为什么这么多使用 vuetify UI 框架的,简单使用下来发现很多坑。持续更新 1、input 和 button 设置相同的 density,但是大小却不一样; 2、表格功能过于简单,没有列拖拽,只有左侧固定列没有右侧固定列&#…

基于Swing和socket实现双向通讯案例

server代码: import javax.swing.*; import java.awt.*; import java.io.*; import java.net.ServerSocket; import java.net.Socket;public class Server extends JFrame {private JTextArea messageArea;private JTextField textField;private PrintWriter write…

像艺术家一样工作:前言

名人名言 “艺术是盗窃” —— 巴勃罗毕加索 “不成熟的诗人模仿,成熟的诗人偷窃;对于偷窃得到的艺术,坏的诗人丑化它,好的诗人加入自己的理解,使它变得更好,至少会让它有点不同。最优秀的诗人&#xff0…

After Effects 2022(AE2022)支持win版和mac版下载

​After Effects 2022 是由Adobe公司推出的一款专业视频后期制作软件,它主要用于视频合成、视频特效制作、视频剪辑、动画制作等领域。After Effects 2022 内置了丰富的特效和过渡效果,用户可以通过它进行高级的视频合成和动画制作。 该软件具有直观的用…

一文搞懂分布式事务Seta-AT模式实现原理

分布式事务概念 分布式事务(Distributed Transaction) 是指在分布式系统中,涉及多个数据库、服务、消息队列等资源,并且需要保证这些资源上的操作要么全部成功提交,要么全部失败回滚的一种机制。在分布式系统中&#…

IO流---字节流.Java

一,概述 IO流是存储和读取数据的解决方案。 I:input O:output流:像水流一样传输数据 因为IO流与File是息息相关的,所以在学习IO流之前,简单回顾一下File:😄😊&#…

python对文本操作,生成可执行文件

.exe文件主要包含pingmianF.py文件和read_inp_auto.py文件 实现效果 代码 read_inp_auto.py #-*- coding: utf-8 -*- import re import sys import os import os.path import time import pingmianF from pingmianF import vector import numpy as np from tkinter import me…

GDPU JavaWeb EL与JSTL

标签化,可以简化百分号的繁忙。 标签库配置 先下载好jstl标签库,然后放到lib。接着,要让编译器识别到,因此要在模块配置依赖,这里导jar包都得注意一下模块依赖。 也可以在libraries项目库设置。 EL与JSTL查询图书 在…

2024华为OD机试真题-攀登者1-C++(C卷D卷)

题目描述 攀登者喜欢寻找各种地图,并且尝试攀登到最高的山峰。 地图表示为一维数组,数组的索引代表水平位置,数组的元素代表相对海拔高度。 其中数组元素0代表地面。 例如: [0,1,2,4,3,1,0,0,1,2,3,1,2,1,0],代表如下图所示的地图, 地图中有两个山脉位置分别为1,2,3,4,5 …

设计模式(十)结构型模式---享元模式

文章目录 享元模式简介结构UML图具体实现UML图代码实现 享元模式简介 享元模式(fly weight pattern)主要是通过共享对象来减少系统中对象的数量,其本质就是缓存共享对象,降低内存消耗。享元模式将需要重复使用的对象分为两个状态…

大学生Python自救课程总结

因为一些事情的缘故,我已经几乎没有更新很久了,然后现在快到期末了,不知道各位学习python的同志们慌不慌【坏笑】。 本学期,我只是简单的讲了讲python的基础用法。当然,可能有些地方总结的并不全面,很多知…

面试高频问题----2

一、进程、线程、协程有什么区别? 1.进程:进程是操作系统中独立运行的程序实例,每个进程都有自己的内存空间和系统资源;进程之间相互独立,每个进程有自己的内存地址空间,一个进程无法直接访问另一个进程的…

MyBatis中的接口代理机制及其使用

1. MyBatis中的接口代理机制及其使用 文章目录 1. MyBatis中的接口代理机制及其使用2. 实操2.1 准备工作2.2 insert 增加操作2.3 delete 删除操作2.4 update 修改操作2.5 select 查询一条记录操作2.6 select 查询多条记录操作 3. 总结:4. 最后: MyBatis …