Flutter 输入组件 Checkbox 详解

目录

[1. 引言](#1. 引言)

[2. Checkbox 的基本用法](#2. Checkbox 的基本用法)

[3. 主要属性](#3. 主要属性)

[4. 自定义 Checkbox 样式](#4. 自定义 Checkbox 样式)

[4.1 带文本标签的 CheckboxListTile](#4.1 带文本标签的 CheckboxListTile)

​编辑

[4.2 使用 tristate 设置三种状态](#4.2 使用 tristate 设置三种状态)

[5. 结论](#5. 结论)

相关推荐


1. 引言

在 Flutter 中,Checkbox 是一个常用的多选组件,适用于设置开关选项、同意协议、筛选条件等场景。Checkbox 允许用户勾选或取消勾选,并可通过 valueonChanged 进行状态管理。本文将介绍 Checkbox 的基本用法、主要属性及自定义样式。

2. Checkbox 的基本用法

Checkbox 需要 value 设定当前选中状态,并通过 onChanged 监听用户交互。

Dart 复制代码
bool isChecked = false;

Checkbox(
  value: isChecked,
  onChanged: (bool? newValue) {
    setState(() {
      isChecked = newValue!;
    });
  },
)

3. 主要属性

属性 说明
value 复选框的当前状态(true 选中,false 未选中)
onChanged 状态变更时的回调函数
activeColor 复选框选中时的颜色
checkColor 复选标记的颜色
tristate 是否支持三态(true / false / null
shape 自定义复选框形状

示例:

Dart 复制代码
Checkbox(
  value: true,
  activeColor: Colors.blue,
  checkColor: Colors.white,
  shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(5)),
  onChanged: (bool? newValue) {},
)

4. 自定义 Checkbox 样式

4.1 带文本标签的 CheckboxListTile

Dart 复制代码
CheckboxListTile(
  title: Text('同意条款'),
  value: isChecked,
  onChanged: (bool? newValue) {
    setState(() {
      isChecked = newValue!;
    });
  },
)

4.2 使用 tristate 设置三种状态

Dart 复制代码
Checkbox(
  tristate: true,
  value: null, // 三态:选中、未选中、部分选中(null)
  onChanged: (bool? newValue) {},
)

5. 结论

Checkbox 是 Flutter 中用于多选的核心组件,适用于多种交互场景。可以结合 CheckboxListTile 提供更丰富的 UI,支持 activeColorshapetristate 等自定义配置。熟练掌握 Checkbox 的使用,有助于创建更友好的用户体验。

相关推荐

Flutter IconButton完全指南:高效使用与性能优化秘籍-CSDN博客文章浏览阅读1.4k次,点赞46次,收藏24次。IconButton 是一个带有图标的按钮组件,通常用于工具栏、导航栏或交互操作。IconButton 继承自 StatelessWidget,支持点击事件、大小、颜色等多种自定义属性。本文将介绍 IconButton 的基本用法、主要属性及自定义样式。https://shuaici.blog.csdn.net/article/details/146069934Flutter TextField 从入门到精通:掌握输入框的完整指南-CSDN博客文章浏览阅读916次,点赞39次,收藏29次。本文全面解析 Flutter TextField 控件的使用技巧,覆盖从基础到进阶的完整知识体系。入门部分讲解基础属性(controller、decoration)、键盘类型设置和文本监听;进阶部分深入探讨表单验证(Form+TextFormField)、自定义输入格式(正则表达式验证)、动态样式修改(圆角/图标/动画)以及高级功能(输入长度限制、防抖处理)。通过代码示例演示手机号输入验证、密码隐藏切换、输入掩码等实战场景,并提供多平台适配、性能优化和无障碍访问等最佳实践方案。_flutter textfieldhttps://shuaici.blog.csdn.net/article/details/146068520

相关推荐
90后的晨仔5 分钟前
从一个简单的登录示例开始解析Combine + MVVM
ios
AD钙奶-lalala15 分钟前
Android 11以上App主动连接WIFI的完整方案
android
大耳猫19 分钟前
Android 中的 DataBinding 详解
android·android jetpack·databinding
玲小珑25 分钟前
Auto.js 入门指南(一)什么是 Auto.js
android·前端
jianleepb2 小时前
2025Flutter(安卓)面试题详解
flutter
Fastcv2 小时前
手把手教你上传安卓库到Central Portal
android·maven·jcenter
我现在不喜欢coding2 小时前
swift中的self,Self,Class(struct).Type让你头大了嘛?
ios·swift
whysqwhw2 小时前
安卓应用线程与架构问题
android
小鱼干coc2 小时前
Android 轻松实现 增强版灵活的 滑动式表格视图
android
Le_ee2 小时前
dvwa6——Insecure CAPTCHA
android·安全·网络安全·靶场·dvwa