深入解析Toggle组件:打造自定义按钮与开关体验 原创

在敲键盘的小鱼干很饥饿
发布于 2024-12-9 21:32
浏览
3收藏

Toggle组件解释

Toggle组件是一个交互式UI组件,用于切换两种状态之间的选择或开关。它通常用于表示开关按钮,例如在设置中启用或禁用某些选项。
在Toggle组件中,用户可以点击按钮来切换状态,或者使用键盘或其他输入设备上的快捷键。通常,Toggle组件会在用户点击或切换状态时触发一个事件,以便应用程序可以响应此更改。

Toggle组件通常包含以下属性:
type:表示当前Toggle组件类型。
isOn:表示当前Toggle组件选中的状态。
onChange:在Toggle组件状态改变时触发的事件处理函数。

创建切换按钮

Button

语法

Toggle({ type: ToggleType.Button, isOn: true } 

ToggleType为Button时,只能包含一个子组件,如果子组件有文本设置,则相应的文本内容会显示在按钮内部。
这个button简单下面给出一个简单的示例。

      Toggle({ type: ToggleType.Button, isOn: false }) {
        Text('按钮')
          .fontColor($r('sys.color.black'))
          .fontSize(12)
      }
      .width(100)
      .selectedColor(Color.Blue)

结果
深入解析Toggle组件:打造自定义按钮与开关体验-鸿蒙开发者社区
我们常用的按钮就之间使用Button组件了,这个就不过多介绍了

当ToggleType为Checkbox或者Switch时,用于创建不包含子组件的Toggle

switch

语法

Toggle({ type: ToggleType.Switch, isOn: true } 

switch其他常用的属性有

  1. switchPointColor
    设置Switch类型的圆形滑块颜色
    switchPointColor(color: ResourceColor)
  2. switchStyle
    设置Switch类型的样式。
    switchStyle(value: SwitchStyle)
    SwitchStyle对象有这些(来自官方文档)
    深入解析Toggle组件:打造自定义按钮与开关体验-鸿蒙开发者社区

下面给出我在开发中画的开关

      Toggle({ type: ToggleType.Switch, isOn: true })
        .width(41)
        .height(21)
        .switchStyle({
          unselectedColor: '#FFFFFF',
          pointRadius: 9
        })
        .switchPointColor('#333333')
        .selectedColor('#E9FAFF')
        .borderRadius(25)
        .border({ color: '#333333', width: 1 })
        .margin({ right: 25 })

        .onChange(() => {
          //深色模式切换
        });

如图所示
深入解析Toggle组件:打造自定义按钮与开关体验-鸿蒙开发者社区

checkbox

语法

Toggle({ type: ToggleType.Checkbox, isOn: true } 

示例代码

    Toggle({ type: ToggleType.Checkbox, isOn: true })
      .size({ width: 20, height: 20 })
      .selectedColor('#007DFF')
      .onChange((isOn: boolean) => {
        console.info('Component status:' + isOn)
      })

如图所示
深入解析Toggle组件:打造自定义按钮与开关体验-鸿蒙开发者社区
在这个toggle里面,默认的checkbox是圆形的,好像不能改。如果要用其他样式的可以直接使用chekbox组件来设置。
使用checkbox组件设置复选框

      Checkbox()
        .width(17)
        .height(15)
        .shape(CheckBoxShape.ROUNDED_SQUARE)
        .select(false)
        .mark({ strokeColor: '#BEFF33' })
        .selectedColor($r('sys.color.black'))
        .borderRadius(6)

深入解析Toggle组件:打造自定义按钮与开关体验-鸿蒙开发者社区
结束。

©著作权归作者所有,如需转载,请注明出处,否则将追究法律责任
已于2024-12-26 12:22:40修改
5
收藏 3
回复
举报
3条回复
按时间正序
/
按时间倒序
wx648063cb367de
wx648063cb367de

我靠,大佬太牛了,解决了困扰我的wen ti

回复
2024-12-10 12:58:23
mb6759406178e33
mb6759406178e33

又了解到了



回复
2024-12-11 15:36:02
Crips
Crips

我靠,大佬太牛了,解决了困扰我的wen ti

回复
2024-12-18 19:27:53
回复
    相关推荐