鸿蒙:用Toggle组件实现选择框、开关样式

1、前言

在鸿蒙app开发过程中,我们经常会遇到让用户勾选选项、打开开关等操作。那么用Toggle组件就可以实现这些功能。

2、参考文档

https://developer.huawei.com/consumer/cn/doc/harmonyos-references/ts-basic-components-togglehttps://developer.huawei.com/consumer/cn/doc/harmonyos-references/ts-basic-components-toggle

3、核心代码

复制代码
 // 创建开关类型的Toggle组件
      // type: ToggleType.Switch 表示是开关样式
      // isOn: $$this.isOn 表示双向绑定isOn状态,开关操作会同步更新isOn的值
      Toggle({ type: ToggleType.Switch, isOn: $$this.isOn })
        .selectedColor('#007DFF')    // 设置开关选中时的颜色(蓝色)
        .switchPointColor('#FFFFFF') // 设置开关滑块的颜色(白色)


      // 创建复选框类型的Toggle组件
      // type: ToggleType.Checkbox 表示是复选框样式
      // 同样双向绑定isOn状态,与开关组件共享同一状态
      Toggle({ type: ToggleType.Checkbox, isOn: $$this.isOn })
        .selectedColor('#007DFF')    // 设置复选框选中时的颜色(蓝色)
        .switchPointColor('#FFFFFF') // 设置复选框内部图标的颜色(白色)

4、运行效果

5、完整代码

复制代码
@Entry
@ComponentV2
struct Index {
  // @Local 装饰器声明这是一个组件内部状态变量,用于管理组件的UI状态
  // isOn 表示开关状态,true为打开,false为关闭,初始值为true
  @Local isOn: boolean = true;

  // @Builder 装饰器声明这是一个UI构建函数,用于封装可复用的UI片段
  // 作用:根据isOn状态显示"打开"或"关闭"文本
  @Builder
  toggleBuilder() {
    Text(this.isOn ? '打开' : '关闭')  // 三元表达式:根据isOn状态切换显示文本
      .fontSize(24)                     // 设置字体大小为24
      .fontWeight(FontWeight.Bold) // 设置字体为粗体
  }

  // build方法是组件的UI构建入口,用于定义组件的布局和内容
  build() {
    // Column为垂直布局容器,{ space: 20 }表示子组件之间的垂直间距为20
    Column({ space: 20 }) {
      // 调用toggleBuilder构建函数,显示当前状态文本(上方)
      this.toggleBuilder()

      // 创建开关类型的Toggle组件
      // type: ToggleType.Switch 表示是开关样式
      // isOn: $$this.isOn 表示双向绑定isOn状态,开关操作会同步更新isOn的值
      Toggle({ type: ToggleType.Switch, isOn: $$this.isOn })
        .selectedColor('#007DFF')    // 设置开关选中时的颜色(蓝色)
        .switchPointColor('#FFFFFF') // 设置开关滑块的颜色(白色)

      // 再次调用toggleBuilder构建函数,显示当前状态文本(下方)
      this.toggleBuilder()

      // 创建复选框类型的Toggle组件
      // type: ToggleType.Checkbox 表示是复选框样式
      // 同样双向绑定isOn状态,与开关组件共享同一状态
      Toggle({ type: ToggleType.Checkbox, isOn: $$this.isOn })
        .selectedColor('#007DFF')    // 设置复选框选中时的颜色(蓝色)
        .switchPointColor('#FFFFFF') // 设置复选框内部图标的颜色(白色)

    }
    .width('100%') // 设置Column宽度为100%父容器宽度
    .height('100%') // 设置Column高度为100%父容器高度
    .justifyContent(FlexAlign.Center) // 设置子组件在垂直方向居中对齐
  }
}

觉得有帮助,可以点赞或收藏

相关推荐
2601_962072551 小时前
李梦娇常识4600问|题库|打印版
sql·华为od·华为·c#·华为云·.net·harmonyos
伶俜661 小时前
鸿蒙原生应用实战(十九)ArkUI 喝水提醒 App:定时通知 + 每日记录 + 统计图表
华为·harmonyos
风华圆舞2 小时前
Flutter + 鸿蒙 Intents Kit:页面直达能力的完整接入方案
flutter·ui·华为·harmonyos
三声三视2 小时前
Electron 在鸿蒙 PC 上跑 webview,我是怎么把首屏从 4.2s 干到 1.1s 的
华为·electron·harmonyos·鸿蒙
互联网散修4 小时前
鸿蒙实战:从0到1构建功能完备的搜索页面
华为·harmonyos
花椒技术4 小时前
RN 多包热更新实践:更新校验、运行时加载与 Bridge 缓存治理
react native·react.js·harmonyos
不喝水就会渴4 小时前
【共创季稿事节】HarmonyOS 7.0 时代的新基建 :DevEco CLI + Claude Code,鸿蒙 AI 开发的黄金搭档
人工智能·华为·harmonyos
星释4 小时前
鸿蒙智能体开发实战:2.创建单Agent
harmonyos·智能体
世人万千丶5 小时前
成语接龙小应用 - HarmonyOS ArkUI 开发实战-TextInput与List列表-PC版本
华为·list·harmonyos·鸿蒙·鸿蒙系统
TrisighT5 小时前
AI写鸿蒙UI:10个跑崩8个,剩下2个看运气
ai编程·harmonyos·arkts