鸿蒙:用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) // 设置子组件在垂直方向居中对齐
  }
}

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

相关推荐
提子拌饭13313 分钟前
风息时钟:鸿蒙Flutter 实现的自然风格时钟应用
flutter·华为·架构·开源·harmonyos
浮芷.3 小时前
Flutter 框架跨平台鸿蒙开发 - AR动物互动应用
flutter·ar·harmonyos
加农炮手Jinx5 小时前
Flutter 组件 conventional 适配鸿蒙 HarmonyOS 实战:约定式提交标准,构建自动化版本治理与 CI/CD 质量治理架构
flutter·harmonyos·鸿蒙·openharmony
王码码20355 小时前
Flutter 三方库 appstream 的鸿蒙化适配指南 - 驾驭 Linux 生态元数据规范,打造高性能、标准化、国际化的 OpenHarmony 桌面应用商店分发基石
flutter·harmonyos·鸿蒙·openharmony
见山是山-见水是水5 小时前
Flutter 框架跨平台鸿蒙开发 - AR植物养护助手
flutter·华为·ar·harmonyos
autumn20056 小时前
Flutter 框架跨平台鸿蒙开发 - 历史人物对话
服务器·flutter·华为·harmonyos
autumn20056 小时前
Flutter 框架跨平台鸿蒙开发 - 社区闲置循环
flutter·华为·harmonyos
chenbin___6 小时前
在鸿蒙手机上,measure 和 measureInWindow 返回的 y / pageY 在滑动组件后值不变问题
华为·智能手机·harmonyos
浮芷.7 小时前
Flutter 框架跨平台鸿蒙开发 - 家庭健康监测云应用
科技·flutter·华为·harmonyos·鸿蒙
世人万千丶8 小时前
Flutter 框架跨平台鸿蒙开发 - 宠物语言翻译器应用
学习·flutter·华为·开源·harmonyos·鸿蒙