鸿蒙学习-
鸿蒙数据传值
//* 传值 //* @State /**@State创建一个响应式的数据,但不是所有的更改都会引起刷新,只有被框架观察到的修改才会被刷新UI* 1. 基本数据类型如 number string boolean等值的变化修改* 2. Object类型,只会观察到第一层的数据变化或者自身数据的赋值变化.原因是,监听多层会消耗巨大的性能* *///* @Prop /** @Prop 父子单项传值* 在父组件中通过参数的方式传递,在子组件中通过@prop接收,如果没有通过@prop接收,那么他就无法得到响应式,* 即无法随着父组件的数据修改而被修改* 在子组件中可以修改@prop传值,但是当父组件修改之后,子组件的依旧会被覆盖* 也可以给子组件传递一个函数,通过接收该函数来修改数据,来实现数据的同步* 在给子组件传递的函数时,应该是一个箭头函数,原因就是this指向问题* *///* @Link 可以实现双向同步绑定 -- 不需要提供默认值//* @Provide @Consume 跨组件传值//* @Observed @ObjectLink 嵌套对象数组 /** 可以直接监听到对象的内层嵌套* 需要通过class类来创建对象* @ObjectLink 不可以使用在Entry入口文件中* UI的更新,不根据数据的更新而更新,而是依附于@ObjectLink* */
interface ClPerson {name:stringage:number
}@Observed
class Person {name:stringage:numberconstructor(infoObj:ClPerson) {this.name = infoObj.namethis.age = infoObj.age}
}@Component
struct Son {@Prop sonMessage :string = ""@Link sonName:stringsonChange=()=>{}build() {Column(){Text(`这是子组件的数据${this.sonMessage}-${this.sonName}`)Button('修改').onClick(()=>{this.sonChange();this.sonName = '本'})}}
}@Component
struct Son2 {@ObjectLink info:Personbuild() {Text(`学生的信息:${this.info.name}-${this.info.age}`)}
}@Entry
@Component
struct Index {@State message: string = 'nihao';@State name:string = "Ben"@State personArr:ClPerson[] = [new Person({name:'ben',age:18}),new Person({name:'ben',age:18})]build() {Column(){Text(`这是父组件的数据${this.message}} - ${this.name}}`)Son({sonMessage:this.message,sonName:this.name,sonChange:()=>{this.message="您好"}})List(){ForEach(this.personArr,(item:ClPerson,index:number)=>{ListItem(){Son2({info:item})}})}}}
}
成员变量和成员函数
//* 成员变量和成员函数 /** 定义在strcu中的变量或者函数*成员变量通过外部传参可以被修改* 成员函数只有箭头函数可以被修改* *///* BuilderParam 传递UI /** 通过BuilderParam可以允许用户在自定义组件中传递UI* 多个BuilderParam传递通过参数的形式而不是尾随闭包* -->* Son({* oneBuilderParam:结构1* twoBuilderParam:结构二* })* */
@Component
struct Son {@BuilderParam contentBuilderParam:()=> void = this.builderParam@State title:string = '默认文本'@BuilderbuilderParam() {Text('默认builderParam')}build() {Column() {Row() {Text(this.title)}this.contentBuilderParam()}}
}@Component
struct Son2 {@BuilderParam Bp1:() => void =this.builderContent1@BuilderParam Bp2:() => void =this.builderContent2@BuilderbuilderContent1() {Text('son2默认文本1')}@BuilderbuilderContent2() {Text('son2默认文本2')}build() {Column() {this.Bp1()this.Bp2()}}
}@Entry
@Component
struct Index {@State message: string = 'nihao';clickFun = () => {console.log('112233')}@BuilderSon21() {Text('这是修改的son2中的1')}@BuilderSon22() {Text('这是被修改的Son2中的2')}build() {Column() {Son({title:'这是标题'}){Button('这是按钮').onClick(()=>{this.clickFun()})}Son2({Bp1:this.Son21,Bp2:this.Son22})}}
@Styles @Builder @Extend
// * swiper组件 /** loop 是否循环* autoplay 是否自动播放* interval 间隔时长* vertical 纵/横* */// * 指示器的样式修改 indicator - false 则不展示 /** Indicator.dot().itemWidth(20) 默认指示器.itemHeight(20).color(Color.Black).selectedItemWidth(40) 选中指示器.selectedItemHeight(20).selectedColor(Color.Red)* */// * aspectRatio(1) 宽高比//* @Extend 扩展组件的样式 事件实现复用 /** @Extend(组件名)* function funName(参1,参2,...) {}* */
@Extend(Text)
function swiperTextExtend(bgc: ResourceColor,msg: string) {.fontSize(20).fontWeight(700).textAlign(TextAlign.Center).backgroundColor(bgc).onClick(()=>{AlertDialog.show({message:msg})})
}
// * @Styles 抽取通用属性和方法 不支持传参 局部的或者外部的调用方法一致
@Styles function commitStyle() {.width(100).height(100)
}
// * @Builder 自定义的构建函数 结构 样式 事件 调用内部方法需要使用 this.funName
interface ImgInter {imgUrl:stringnumber:numbergetImg:string
}@Builder
function commitBuilder(number:number,getImg:string,imgUrl:string) {Badge({count:number,position:BadgePosition.RightTop,style:{fontSize:12,badgeSize:16,badgeColor:"#d7000f"}}){Image($r(getImg ? getImg: imgUrl)).width(60)}
}@Entry
@Component
struct Index {@State message: string = 'nihao';@Styles commitFun() {.onClick(()=>{this.message = '你好'})}@State imgArr: ImgInter[] = [{imgUrl:'app.media.cj_01',number:0,getImg:''},{imgUrl:'app.media.cj_02',number:0,getImg:''},{imgUrl:'app.media.cj_03',number:0,getImg:''},{imgUrl:'app.media.cj_04',number:0,getImg:''},{imgUrl:'app.media.cj_05',number:0,getImg:''},{imgUrl:'app.media.cj_06',number:0,getImg:''},]build() {Column(){Swiper(){Text("1").swiperTextExtend(Color.Orange,'弹窗1')Text("2").swiperTextExtend(Color.Pink,'弹窗2')Text("3").swiperTextExtend(Color.Green,'弹窗3')}.width("100%").height(250).loop(true).autoPlay(true).interval(4000).vertical(false).indicator(Indicator.dot().itemWidth(20).itemHeight(20).color(Color.Black).selectedItemWidth(40).selectedItemHeight(20).selectedColor(Color.Red))Text('这是文本:'+this.message).commitStyle().commitFun()Grid(){ForEach(this.imgArr,(item:ImgInter,index:number)=> {GridItem(){commitBuilder(item.number,item.getImg,item.imgUrl)}})}.columnsTemplate('1fr 1fr 1fr').rowsTemplate('1fr 1fr 1fr').width('100%').height(200)}}
}
scroll
// * scroll /** scroll 中只允许拥有一个子组件** 属性* scrollable:* ScrollDirection.Horizontal 横向* ScrollDirection.Vertical 纵向* scrollBar: 控制滚动条显示隐藏* BarState.On 打开* BarState.Off 关闭* edgeEffect: 滑动的动态效果* Spring Fade** 控制器* 1. 创建scroller实例* 2. 绑定scroll组件* 3. 调用方法 scrollEdge()* */
@Entry
@Component
struct Index {@State message: string = 'nihao';scroll: Scroller = new Scroller();build() {Column(){Scroll(this.scroll){Column({space:20}){ForEach(Array.from({length:20}),(item:number,index:number)=> {Text('这是文本'+index).width('100%').height(120).borderRadius(8).fontSize(20).fontWeight(800).backgroundColor(Color.Orange).fontColor(Color.White)})}}.width("100%").padding(10).height(400).scrollable(ScrollDirection.Vertical).scrollBar(BarState.Off).scrollBarColor(Color.Pink).scrollBarWidth(30).edgeEffect(EdgeEffect.Spring).onScroll((x,y)=>{console.log('滚动到',this.scroll.currentOffset().yOffset)})Button('回到顶部').margin(20).onClick(()=>{this.scroll.scrollEdge(Edge.Top)})Button('获取已经滚动的距离').onClick(()=>{const y = this.scroll.currentOffset().yOffsetconsole.log('这是y',y)})}}
tabs
//* tabs /** 属性* barposition 调整位置* vertical 垂直 / 水平* scrollable 是否手势滑动切换* animationDuration 滑动时间* barMode 是否滑动* */
@Entry
@Component
struct Index {@State message: string = 'nihao';@State selectIndex: number = 0@BuildermyTabs(tabIndex:number,img:ResourceStr,selectImg:ResourceStr,title:string) {Column({space:4}){Image(tabIndex == this.selectIndex ? selectImg : img).width(20)Text(title).fontColor(tabIndex == this.selectIndex ? Color.Red : Color.Black)}}build() {// Tabs({barPosition:BarPosition.Start}){// TabContent(){// Text('首页内容')// }.tabBar('首页')// TabContent(){// Text('推荐内容')// }.tabBar('推荐')// TabContent(){// Text('列表内容')// }.tabBar('列表')// TabContent(){// Text('我的内容')// }.tabBar('我的')// }// .vertical(true)// .scrollable(false)// .animationDuration(1000)// .barMode(BarMode.Scrollable)Tabs({barPosition:BarPosition.End}){TabContent(){Text('淘宝页面')}.tabBar(this.myTabs(0,$r('app.media.cj_01'),$r('app.media.cj_d01'),'淘宝'))TabContent(){Text('QQ页面')}.tabBar(this.myTabs(1,$r('app.media.cj_02'),$r('app.media.cj_d02'),'QQ'))}.onChange((index:number)=> {this.selectIndex = index})}
}
数据格式和state状态管理
// 数据的格式转换 // * 数字转字符串 /** Number() let a = '1.1' Number(a) => 1.1 转失败则为NaN* parseInt() 去掉小数点部分* parseFloat() 保留小数点部分 let a = '1.1a' parseFloat(a) => 1.1 自动去掉字符部分* */ // * 字符串转数字 /** toString() let a = 1 a.toString()* toFixed 四舍五入转文本* */// * 状态管理 state /** 核心 state会直接决定UI的初始化渲染,UI一旦发生交互,就会修改state变量,state变量发生变化自动触发UI渲染* 普通变量:只会在初始化的时候渲染UI,后续变化无法直接渲染* 状态变量:只要发生变化就可以渲染UI* */
let myName: string = 'Ben'@Entry
@Component
struct Index {@State message: string = 'nihao';myAge:number = 18build() {Column(){Text(myName)Text(this.myAge.toString())Text(this.message)Button('修改Message').onClick(()=> {this.message = '你好,你会找到一个满意的工作';console.log('1122')})}}
}
相关文章:
鸿蒙学习-
鸿蒙数据传值 //* 传值 //* State /**State创建一个响应式的数据,但不是所有的更改都会引起刷新,只有被框架观察到的修改才会被刷新UI* 1. 基本数据类型如 number string boolean等值的变化修改* 2. Object类型,只会观察到第一层的数据变化或…...
list结构刨析与模拟实现
目录 1.引言 2.C模拟实现 2.1模拟实现结点 2.2模拟实现list前序 1)构造函数 2)push_back函数 2.3模拟实现迭代器 1)iterator 构造函数和析构函数: *操作符重载函数: 前置/后置/--: /!操作符重载…...

机器人部分专业课
华东理工 人工智能与机器人导论 Introduction of Artificial Intelligence and Robots 必修 考查 0.5 8 8 0 1 16477012 程序设计基础 The Fundamentals of Programming 必修 考试 3 64 32 32 1 47450012 算法与数据结构 Algorithm and Data Structure 必修 考试 3 56 40 …...

流行粗野主义几何风现代曲线标题logo设计psai无衬线英文字体安装包 Mortend – Extended Family
介绍我们名为 Mortend 的新探索,这是一个强大的扩展字体系列。Mortend 的设计具有几何形状、大胆、强烈的曲线和现代感。灵感来自当今流行的粗野主义海报和极简主义设计,让您有更多机会表达您的创造力。这个字体系列带来了强烈的感觉而优雅的外观&#x…...

前端常见面试题-2025
vue4.0 Vue.js 4.0 是在 2021 年 9 月发布。Vue.js 4.0 是 Vue.js 的一个重要版本,引入了许多新特性和改进,旨在提升开发者的体验和性能。以下是一些关键的更新和新特性: Composition API 重构:Vue 3 引入了 Composition API 作为…...

高通Camera点亮3——Camera Module
Camera点亮除了Sensor之外还需要配置module、EEPROM等,multicamera;配置好编译设置。 Module <?xml version"1.0" encoding"utf-8" ?> <cameraModuleData<!--Module group can contain either 1 module or 2 modules…...

学习路程二 LangChain基本介绍
前面简单调用了一下deepseek的方法,发现有一些疑问和繁琐的问题,需要更多的学习,然后比较流行的就是LangChain这个东西了。 目前大部分企业都是基于 LangChain 、qwen-Agent、lammaIndex框架进行大模型应用开发。LangChain 提供了 Chain、To…...

Docker-技术架构演进之路
目录 一、概述 常见概念 二、架构演进 1.单机架构 2.应用数据分离架构 3.应用服务集群架构 4.读写分离 / 主从分离架构 5.引入缓存 —— 冷热分离架构 6.垂直分库 7.业务拆分 —— 微服务 8.容器化引入——容器编排架构 三、尾声 一、概述 在进行技术学习过程中&am…...
API接口设计模式:从分层架构到CQRS的实战应用
以下将从分层架构和 CQRS(命令查询职责分离)的基本概念入手,为你阐述从分层架构到 CQRS 的实战应用相关内容: 分层架构 概念:分层架构是将系统按照功能划分为不同的层次,每个层次负责特定的职责,…...

【机器学习】【KMeans聚类分析实战】用户分群聚类详解——SSE、CH 指数、SC全解析,实战电信客户分群案例
1.引言 在实际数据分析中,聚类算法常用于客户分群、图像分割等场景。如何确定聚类数 k 是聚类分析中的关键问题之一。本文将以“用户分群”为例,展示如何通过 KMeans 聚类,利用 SSE(误差平方和,也称 Inertiaÿ…...
【C++】 时间库chrono计算程序运行时间
C 时间库chrono计算程序运行时间 本文总结了chrono库的引入方法以及计算程序片段运行时间的方法 一、chrono库的引入方法(注意事项) 首先chrono是属于std命名空间的。 所以在程序中应该这样包含头文件: #include <chrono> using n…...
PCL 边界体积层次结构(Boundary Volume Hierarchy, BVH)
文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 边界体积层次结构(Boundary Volume Hierarchy, BVH) 是一种高效的空间数据结构,广泛应用于计算机图形学、计算机视觉、机器人学、物理仿真等领域。它的核心思想是通过将空间递归地划分为层次化的包围体(通常是轴…...
算法随笔_58: 队列中可以看到的人数
上一篇:算法随笔_57 : 游戏中弱角色的数量-CSDN博客 题目描述如下: 有 n 个人排成一个队列,从左到右 编号为 0 到 n - 1 。给你以一个整数数组 heights ,每个整数 互不相同,heights[i] 表示第 i 个人的高度。 一个人能 看到 他右边另一个人…...

创建React项目的三个方式
创建React项目 创建一个React项目非常简单,通常有几种方法可以进行,下面是最常见的几种方法: 1. 使用 create-react-app (已经不被推荐了) create-react-app 是一个官方的脚手架工具,用于快速创建 React 项目。它会为你配置好很…...
QT闲记-工具栏
工具栏通常用来放置常用的操作按钮,如QPushButton,QAction等。可以放置在顶部,底部,左侧,右侧,并且支持拖曳,浮动。 1、创建工具栏 通常通过QMainWindow 提供的addToolBar()来创建,它跟菜单栏一样,如果需要工具栏,一般情况下,我们设置这个类的基类为QMainWindow。 …...

为什么继电器要加一个反向并联一个二极管
1 动感就是电流不突变 2 为什么有的继电器上面要反向并联一个二极管和电阻 1 并联二极管是为消除掉动感产生的高压 2 加上二极管是为了让继电器更快的断开(二极管选型的工作电流要大于动感电流,开关要够快) 3 公式:二极管压降0…...
【Leetcode 每日一题 - 扩展】1512. 好数对的数目
问题背景 给你一个整数数组 n u m s nums nums。 如果一组数字 ( i , j ) (i,j) (i,j) 满足 n u m s [ i ] n u m s [ j ] nums[i] nums[j] nums[i]nums[j] 且 i < j i < j i<j,就可以认为这是一组 好数对 。 返回好数对的数目。 数据约束 1 ≤ n …...
vue3 采用xlsx库实现本地上传excel文件,前端解析为Json数据
需求:本地上传excel 文件,但需要对excel 文件的内容进行解析,然后展示出来 1. 安装依赖 首先,确保安装了 xlsx 库: bash复制 npm install xlsx 2. 创建 Vue 组件 创建一个 Vue 组件(如 ExcelUpload.v…...

计算机视觉:经典数据格式(VOC、YOLO、COCO)解析与转换(附代码)
第一章:计算机视觉中图像的基础认知 第二章:计算机视觉:卷积神经网络(CNN)基本概念(一) 第三章:计算机视觉:卷积神经网络(CNN)基本概念(二) 第四章:搭建一个经典的LeNet5神经网络(附代码) 第五章࿱…...

FPGA DSP:Vivado 中带有 DDS 的 FIR 滤波器
本文使用 DDS 生成三个信号,并在 Vivado 中实现低通滤波器。低通滤波器将滤除相关信号。 介绍 用DDS生成三个信号,并在Vivado中实现低通滤波器。低通滤波器将滤除较快的信号。 本文分为几个主要部分: 信号生成:展示如何使用DDS&am…...

TDengine 快速体验(Docker 镜像方式)
简介 TDengine 可以通过安装包、Docker 镜像 及云服务快速体验 TDengine 的功能,本节首先介绍如何通过 Docker 快速体验 TDengine,然后介绍如何在 Docker 环境下体验 TDengine 的写入和查询功能。如果你不熟悉 Docker,请使用 安装包的方式快…...
Python爬虫(二):爬虫完整流程
爬虫完整流程详解(7大核心步骤实战技巧) 一、爬虫完整工作流程 以下是爬虫开发的完整流程,我将结合具体技术点和实战经验展开说明: 1. 目标分析与前期准备 网站技术分析: 使用浏览器开发者工具(F12&…...

Python爬虫(一):爬虫伪装
一、网站防爬机制概述 在当今互联网环境中,具有一定规模或盈利性质的网站几乎都实施了各种防爬措施。这些措施主要分为两大类: 身份验证机制:直接将未经授权的爬虫阻挡在外反爬技术体系:通过各种技术手段增加爬虫获取数据的难度…...

HBuilderX安装(uni-app和小程序开发)
下载HBuilderX 访问官方网站:https://www.dcloud.io/hbuilderx.html 根据您的操作系统选择合适版本: Windows版(推荐下载标准版) Windows系统安装步骤 运行安装程序: 双击下载的.exe安装文件 如果出现安全提示&…...

【配置 YOLOX 用于按目录分类的图片数据集】
现在的图标点选越来越多,如何一步解决,采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集(每个目录代表一个类别,目录下是该类别的所有图片),你需要进行以下配置步骤&#x…...

k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
【HarmonyOS 5 开发速记】如何获取用户信息(头像/昵称/手机号)
1.获取 authorizationCode: 2.利用 authorizationCode 获取 accessToken:文档中心 3.获取手机:文档中心 4.获取昵称头像:文档中心 首先创建 request 若要获取手机号,scope必填 phone,permissions 必填 …...

网站指纹识别
网站指纹识别 网站的最基本组成:服务器(操作系统)、中间件(web容器)、脚本语言、数据厍 为什么要了解这些?举个例子:发现了一个文件读取漏洞,我们需要读/etc/passwd,如…...

使用Spring AI和MCP协议构建图片搜索服务
目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式(本地调用) SSE模式(远程调用) 4. 注册工具提…...

Golang——6、指针和结构体
指针和结构体 1、指针1.1、指针地址和指针类型1.2、指针取值1.3、new和make 2、结构体2.1、type关键字的使用2.2、结构体的定义和初始化2.3、结构体方法和接收者2.4、给任意类型添加方法2.5、结构体的匿名字段2.6、嵌套结构体2.7、嵌套匿名结构体2.8、结构体的继承 3、结构体与…...