当前位置: 首页 > news >正文

HarmonyOS Next星河版笔记--界面开发(5)

1.字符串

1.1.字符串拼接

作用:把两个或多个字符串,拼成一个字符串。(通常是用来拼接字符串和变量)

'hello' + 'world'  =>  'helloworld'

加好作用:拼接

let name:string = '小明'
console.log('简介信息','名字是' + name)
let name:string = '吕布'
let age:number = 18
console.log('简介信息' ,'姓名' + name)
let num1:number = 100
let num2:number = 200
console.log('总数',num1 + num2)

日志页面效果

1.2.模板字符串`hello`

作用:拼接字符串和变量

优势:更适合于多个变量的字符串拼接

let name:string = '吕布'
let age:number = 18
console.log('简介信息',`姓名是${name},今年${age}岁了`)

日志页面效果

2.类型转换(数字和字符串)

2.1.字符串转数字

//字符串转数字
//Number():字符串直接转数字转换失败返回NaN(字符串中包含非数字)
// parseInt():去掉小数部分转数字转换失败返回NaN
// parseFloat():保留小数部分转数字,转换失败返回NaN
let money:string = '1000'
let money2:number = 500
console.log('总工资',Number(money) + money2)//1500

2.2.数字转字符串

作用:字符串用于展示

toString():数字直接转字符串

toFixed():四舍五入转字符串,可设置保留几位小数

3.交互——点击事件

说明:组件被点击是触发的事件

作用:监听感知用户点击行为,进行对应操作

语法:onClick(参数) =>{})

Button('点我,显示弹窗')
.onClink(() =>{
AlertDialog.show({
message:'你好——这里是弹窗'
})
})

4.状态管理

之前构建的页面多为静态界面

但如果希望构建一个动态的、有交互的界面,就需要引入状态的概念

点击交互触发了文本状态变更,状态变更引起了UI渲染

普通变量:只能在初始化时渲染,后续将不会再刷新。

状态变量:需要装饰器装饰,改变会引起UI的渲染刷新(必须设置类型和初始值)

//状态管理
let msg1:string = '青菜'//普通变量@Entry
@Component
struct Index {msg2:string = '黑马'//@State message: string = 'Hello World';//状态变量build() {
Column(){Text(msg1)Text(this.msg2)//this自己的
}}}
//状态管理
let msg1:string = '青菜'//普通变量@Entry
@Component
struct Index {msg2:string = '黑马'//@State message: string = 'Hello World';build() {
Column(){Text(msg1)Text(this.msg2)//this自己的
}}}
//状态管理
//1、普通变量,只能在初始化是渲染,后续就算变化了,也不会引起更新
//2、状态变量,被装饰器修饰,值会改变,会自动引起界面的刷新//组件外的[普通变量]不需要this
let myName:string = '青菜'//普通变量@Entry
@Component
struct Index {//组件内的 [ 普通变量 ] this×××
myAge:number = 18//组件内的状态变量 this×××@State myMsg: string = 'Hello World';//装饰器build() {
Column() {Text(myName).onClick(()=>{
myName = '白菜'//点击无变化console.log('myName',myName)})Text(this.myAge.toString()).onClick(()=>{this.myAge = 20console.log('myAge',this.myAge)})Text(this.myMsg).onClick(()=>{this.myMsg = 'haoyao'})
}}}

5.计数器案例

思路

  1. 准备 状态变量 → @State count:number = 1
  2. 注册点击事件→ onClick
  3. 点击时,修改状态变量
  4. 状态变量变化,界面自动更新
@Entry
@Component
struct Index {//状态变量@State count: number = 1;build() {
Row(){Button('-').onClick(()=>{this.count -= 1})Text(this.count.toString()).padding(20).margin(10)Button('+').onClick(()=>{this.count += 1})
}}

6.点赞案例

思路:

  1. 注册点击事件→onClick
  2. 点击时候,修改颜色,修改数字
    1. 提取颜色为状态变量
    2. 提取数字为状态变量

7.一元、比较、逻辑运算符

7.1.一元运算符

  • 后置写法:先赋值后自增/自减
  • 前置写法:先自增/自减再赋值

7.2.比较运算符

作用:用来判断比较两个数据大小,返回一个布尔值(true/false)

//判断密码是否正确
let password:string = '123456'
let password2 :string = '1234567'
console.log('判断结果',password == password2)//false

7.3.逻辑运算符

作用:扩充判断条件

7.3.运算符优先级

http://www.lryc.cn/news/485379.html

相关文章:

  • Spring Boot3 实战案例合集上线了
  • 在Ubuntu 24.04 LTS上安装飞桨PaddleX
  • Homebrew 命令大全
  • Docker+Django项目部署-从Linux+Windows实战
  • 前端 JS 实用操作总结
  • 11.15 机器学习-集成学习方法-随机森林
  • 【SQL】E-R模型(实体-联系模型)
  • C/C++静态库引用过程中出现符号未定义的处理方式
  • 『VUE』27. 透传属性与inheritAttrs(详细图文注释)
  • 借助Excel实现Word表格快速排序
  • 数据结构 ——— 层序遍历链式二叉树
  • 使用 Prompt API 与您的对象聊天
  • SpringBoot整合Mybatis-Plus实践汇总
  • 基于Spring Boot的在线性格测试系统设计与实现(源码+定制+开发)智能性格测试与用户个性分析平台、在线心理测评系统的开发、性格测试与个性数据管理系统
  • Python实现人脸识别算法并封装为类库
  • uniapp小程序分享使用canvas自定义绘制 vue3
  • SpringCloud核心组件(四)
  • 如何把本地docker 镜像下载用到centos系统中呢?
  • Godot的开发框架应当是什么样子的?
  • GitHub新手入门 - 从创建仓库到协作管理
  • 作业25 深度搜索3
  • ubuntu20.04 colmap 安装2024.11最新
  • WebRTC视频 03 - 视频采集类 VideoCaptureDS 上篇
  • python os.path.basename(获取路径中的文件名部分) 详解
  • 《FreeRTOS任务基础知识以及任务创建相关函数》
  • 036集——查询CAD图元属性字段信息:窗体显示(CAD—C#二次开发入门)
  • Swift从0开始学习 函数和闭包 day2
  • 内网、公网(外网)划分
  • 【linux】centos7 换阿里云源
  • 用OMS进行 OceanBase 租户间数据迁移的测评