学习鸿蒙基础(5)

一、honmonyos的page路由界面的路径

新建了一个page,然后删除了。运行模拟器的时候报错了。提示找不到这个界面。原来是在路由界面没有删除这个page。新手刚接触找了半天才找到这个路由。在resources/base/profile/main_pages.json 这个和微信小程序好类似呀。

吐槽:华为模拟器启动起来好慢呀。等的花儿都快谢了。并且输入法没有中文。太坑了吧。

二、@State组件

@state装饰的变量,或称为状态变量,一旦变量拥有了状态属性,就和自定义组件的渲染绑定起来。当状态改变时,UI会发生对应的改变。

1、当装饰的数据类型为boolean、string、number类型时,可以观察到数值的变化。

2、当装饰的数据类型为class或者Object时,可以观察到自身的赋值的变化,和其属性赋值的变化。注意:嵌套属性的赋值观察不到。

3、当装饰的对象是array时,可以观察到数组本身的赋值和添加、删除、更新数组的变化。

state修饰符修饰的时候,

@state修饰数组的时候,filter作为过滤器进行数组搜索的过滤。实现一个数组列表的简单搜索功能

代码如下:

TypeScript 复制代码
import bankList from '../utils/bankName'

@Entry
@Component
struct TestState {
  @State banks: any [] = bankList
  @State value: string = ""

  build() {
    Row() {
      Column() {
        TextInput().onChange(value => {
          console.log(value)
          this.value = value
        })
        List() {
          ForEach(this.getCop(), (item, index) => {
            ListItem() {
              Text(item.value).fontSize(20).textAlign(TextAlign.Center).width("100%")
            }.margin(10)
          })
        }.height(500).divider({
          strokeWidth: 1,
          color: Color.Blue,
          startMargin: 40,
          endMargin: 40
        })
      }
    }
  }

  getCop() {
    //数组的filter是过滤器
    return this.banks.filter(item =>item.value.includes(this.value))
  }
}
TypeScript 复制代码
const  list = [
  {
    value: 'CCB',
    text: '中国建设银行'
  },
  {
    value: 'ABC',
    text: '中国农业银行'
  },
  {
    value: 'BOC',
    text: '中国银行'
  },
  {
    value: 'PSBC',
    text: '中国邮政储蓄银行'
  },
  {
    value: 'ICBC',
    text: '中国工商银行'
  },

  {
    value: 'COMM',
    text: '交通银行'
  },
  {
    value: 'CDB',
    text: '国家开发银行'
  },
  {
    value: 'GSBANK',
    text: '甘肃银行'
  },
  {
    value: 'CMB',
    text: '招商银行'
  },
  {
    value: 'SPDB',
    text: '上海浦东发展银行'
  },
  {
    value: 'CIB',
    text: '兴业银行'
  }
];
export default list
相关推荐
fox_lht32 分钟前
14.6.将错误重定向到标准错误
开发语言·后端·学习·rust
fanged41 分钟前
Linux内核学习17--SPI子系统(TODO)
学习
The moon forgets1 小时前
跨本体机器人学习:人类运动解码通用物理交互
学习·机器人·交互·具身智能·vla
wzg19690226wzg1 小时前
rust 学习 泛型
开发语言·学习·rust
舟遥遥娓飘飘2 小时前
文稿起草系统,离线学习写作人的“思维 + 风格“,按学到的特征起草新文稿,再用反馈闭环持续提升
windows·学习
踏着七彩祥云的小丑2 小时前
Go学习第5天:变量作用域 + 数组 + 指针
开发语言·学习·golang·go
MartinYeung53 小时前
[论文学习]针对 LLM 的间接提示注入攻击用于高效隐私洩露之深度分析
人工智能·学习
AI棒棒牛3 小时前
YOLO26 全网独家改进创新: MIT 2025 振荡状态空间模型:引入可学习的阻尼机制,独家创新!
人工智能·学习·目标检测·计算机视觉·yolo26
留白_3 小时前
pandas进阶学习
学习·pandas
_Evan_Yao3 小时前
递归函数入门:以阶乘和斐波那契数列为例
python·学习·算法