flutter实践:DropdownButton2使用示例

flutter实现下拉组件

dropdown_button2: '2.3.9'

Dart 复制代码
 @override
  Widget build(BuildContext context) {
    // TODO: implement build
    return DropdownButtonHideUnderline(
      child: DropdownButton2<String>(
        isExpanded: true,
        selectedItemBuilder: (context) {
          return List<Widget>.generate(widget.module.items.length, (index) {
            return _buildSelectedItem(index);
          });
        },
        hint: Row(
          mainAxisAlignment: MainAxisAlignment.center,
          children: [
            Text(
              widget.module.selectedValue,
              textAlign: TextAlign.center,
              style: TextStyle(
                fontSize: widget.themeData.fontSizeBase,
                fontWeight: FontWeight.normal,
                color: widget.themeData.colorTextSecondary,
              ),
              overflow: TextOverflow.ellipsis,
            )
          ],
        ),
        items: widget.module.items
            .map((String item) => DropdownMenuItem<String>(
                  value: item,
                  child: Column(
                    mainAxisAlignment: MainAxisAlignment.start,
                    crossAxisAlignment: CrossAxisAlignment.center,
                    children: [
                      _buildDropItem(item),
                      Visibility(
                        visible: widget.module.items.length !=
                            widget.module.items.indexOf(item) + 1,
                        child: Divider(
                          height: 1,
                          thickness: 1,
                          color: widget.themeData.dividerColorBase,
                        ),
                      ),
                    ],
                  ),
                ))
            .toList(),
        value: widget.module.selectedValue,
        onChanged: (value) {
          setState(() {
            widget.module.selectedValue = value ?? '';
            widget.onValueChanged!(widget.module.selectedValue);
          });
        },
        buttonStyleData: ButtonStyleData(
          height: widget.themeData.heightSm,
          width: widget.themeData.heightSm,
          // padding: const EdgeInsets.only(left: 14, right: 14),
          decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(widget.themeData.radiusSm),
            // border: Border.all(
            //   color: Colors.black26,
            // ),
            color: widget.themeData.dividerColorBase,
          ),
          elevation: 1,
        ),
        // iconStyleData: const IconStyleData(
        //   icon: Icon(
        //     Icons.arrow_forward_ios_outlined,
        //   ),
        //   iconSize: 14,
        //   iconEnabledColor: Colors.yellow,
        //   iconDisabledColor: Colors.grey,
        // ),
        iconStyleData: const IconStyleData(
          icon: SizedBox(),
          iconSize: 0,
          // iconEnabledColor: Colors.yellow,
          // iconDisabledColor: Colors.grey,
        ),
        dropdownStyleData: DropdownStyleData(
          maxHeight: widget.themeData.heightXxl * widget.module.items.length,
          width: widget.style == 0 ? widget.themeData.heightXxxl : 80,
          padding: EdgeInsets.zero,
          // scrollPadding: EdgeInsets.zero,
          decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(widget.themeData.radiusLg),
            color: widget.themeData.fillBase,
          ),
          offset:
              widget.style == 0 ? const Offset(-20, -4) : const Offset(-52, -4),
          scrollbarTheme: ScrollbarThemeData(
            radius: const Radius.circular(40),
            thickness: MaterialStateProperty.all(0),
            thumbVisibility: MaterialStateProperty.all(false),
            trackVisibility: MaterialStateProperty.all(false),
          ),
        ),
        menuItemStyleData: MenuItemStyleData(
          height: widget.themeData.heightXxl,
          padding: EdgeInsets.only(
              left: widget.themeData.hSpacingSm,
              right: widget.themeData.hSpacingSm),
        ),
      ),
    );
  }

value:当前选中的值(必须与items中某一项value相等)

onChanged:用户选择某项时的回调

items:下拉选项列表

hint:未选择时显示的提示文本/控件

dropdownStyleData:配置下拉菜单面板样式

buttonStyleData:配置下拉按钮本身的样式

menuItemStyleData:配置每个下拉选项(item)样式

isExpanded:是否撑满父容器宽度

selectedItemBuilder:自定义 下拉按钮中显示的"已选项"内容(即选中后在按钮上显示的 Widget),不影响下拉菜单中的选项显示

iconStyleData:专门用于 定制下拉按钮右侧的图标(通常是 ▼ 箭头)

相关推荐
stringwu1 小时前
Flutter PopScope:iOS左滑返回失效分析与方案探讨
flutter
500841 小时前
鸿蒙 Flutter 蓝牙与 IoT 开发进阶:BLE 设备连接、数据交互与设备管理
flutter·华为·electron·wpf·开源鸿蒙
子春一1 小时前
Flutter 测试金字塔:从单元测试到端到端验证的完整工程实践
flutter·单元测试
kirk_wang2 小时前
Flutter 图表库 fl_chart 鸿蒙端适配实践
flutter·移动开发·跨平台·arkts·鸿蒙
空中海2 小时前
1.Flutter 简介与架构原理
flutter·架构
晚霞的不甘2 小时前
从单设备到全场景:用 Flutter + OpenHarmony 构建“超级应用”的完整架构指南
flutter·架构
小a彤3 小时前
Flutter 实战教程:构建一个天气应用
flutter
克喵的水银蛇3 小时前
Flutter 通用列表项封装实战:适配多场景的 ListItemWidget
前端·javascript·flutter
Non-existent9873 小时前
Flutter + FastAPI 30天速成计划自用并实践-第7天
flutter·oracle·fastapi
帅气马战的账号3 小时前
开源鸿蒙+Flutter:跨端开发的分布式协同与数据互通实践
flutter