MAUI 的 Switch 控件是一个轻量、语义明确的布尔切换按钮,用于表示“开/关”状态,底层映射到各平台原生开关(如 iOS 的 UISwitch、Android 的 SwitchCompat)。它不依赖复杂逻辑,但用对几个关键属性和事件,就能实现清晰交互与定制外观。
基础用法:声明与绑定
Switch 默认处于关闭状态(
IsToggled="False"),只需设置该属性即可初始化状态。支持 XAML 声明和 C# 代码两种方式: XAML 中直接使用:
<switch istoggled="True"></switch>C# 中创建:
var mySwitch = new Switch { IsToggled = true };
推荐绑定 ViewModel 中的 bool 属性,例如:IsToggled="{Binding IsNotificationsEnabled}",便于响应式更新
自定义外观:颜色控制
Switch 提供三个可设颜色属性,无需写平台特定代码即可统一调整视觉风格:
OnColor:开关滑动到“开启”时背景色(如绿色Colors.Green) OffColor:开关处于“关闭”时背景色(如灰色
Colors.Gray) ThumbColor:中间滑块(thumb)的颜色(如白色
Colors.White) 示例 XAML:
<switch oncolor="Green" offcolor="#E0E0E0" thumbcolor="White"></switch>
监听状态变化:Toggled 事件
用户点击或程序修改
IsToggled都会触发
Toggled事件,传入
ToggledEventArgs,其
Value属性即为最新状态值: XAML 中绑定:
<switch toggled="OnSwitchToggled"></switch>C# 事件处理:
switchControl.Toggled += (s, e) => { if (e.Value) DoEnable(); else DoDisable(); };
注意:避免在事件中反复赋值 IsToggled,否则可能引发循环触发
无障碍与语义支持
Switch 天然支持屏幕阅读器,但需配合语义属性提升可访问性:
用AutomationProperties.Name明确说明用途,例如:
AutomationProperties.Name="启用夜间模式"若放在
SwitchCell(常用于 TableView 设置页),系统会自动关联文本,更易被读出 不建议仅靠颜色区分状态,尤其对色觉障碍用户——可额外加图标或文字标签辅助
基本上就这些。不复杂但容易忽略细节,比如忘记处理权限(虽 Switch 本身无需权限)、或误把
Toggled当成只响应用户操作(其实代码赋值也会触发)。用好这四点,Switch 就能既好用又专业。
