Flutter:下拉框选择

![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/d4![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/42534ef9c696405ba309f73bc3fd8dad.png)

b70dec92594838a8b2c130717938aa.png)

文档地址dropdown_button2

js 复制代码
  // 限价、市价 状态
  final List<String> orderTypes = ['普通委托', '市价委托'];
  String? selectedOrderType = '普通委托';
  changeOrderType(String type) {
    selectedOrderType = type;
    update(["continuous"]);
  }

  // 杠杆
  final List<String> leverages = ['1X', '5X', '10X', '20X', '50X'];
  String? selectedLeverage = '1X';
  changeLeverage(String leverage) {
    selectedLeverage = leverage;
    update(["continuous"]);
  }



  // 委托
  Widget _buildLeftOrderType() {
    return DropdownButtonHideUnderline(
      child: DropdownButton2<String>(
        isExpanded: true,
        value: controller.selectedOrderType,
        items: controller.orderTypes.map((item) => DropdownMenuItem<String>(
          value: item,
          child: TextWidget.body(item,size: 26.sp,color: AppTheme.color000,),
        )).toList(),
        onChanged: (value) {
          controller.changeOrderType(value!);
        },
        buttonStyleData: ButtonStyleData(
          height: 72.w, // 高度和你的红框一致
          width: 180.w, // 宽度自适应父容器
          padding: EdgeInsets.only(left: 20.w, right: 0,),
          decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(10.w),
            color: AppTheme.colorGreen,
          ),
        ),
        dropdownStyleData: DropdownStyleData(
          width: null, // 跟随按钮宽度
          decoration: BoxDecoration(
            color: AppTheme.dividerColor,
            borderRadius: BorderRadius.circular(4),
          ),
          offset: const Offset(0, 0), // 默认正下方弹出
        ),
      ),
    );
  }

  // 杠杆
  Widget _buildLeftLeverage() {
    return DropdownButtonHideUnderline(
      child: DropdownButton2<String>(
        isExpanded: true,
        value: controller.selectedLeverage,
        items: controller.leverages.map((item) => DropdownMenuItem<String>(
          value: item,
          child: TextWidget.body(item,size: 26.sp,color: AppTheme.color000,),
        )).toList(),
        onChanged: (value) {
          controller.changeLeverage(value!);
        },
        buttonStyleData: ButtonStyleData(
          height: 72.w, // 高度和你的红框一致
          width: 140.w, // 宽度自适应父容器
          padding: EdgeInsets.only(left: 20.w, right: 0,),
          decoration: BoxDecoration(
            borderRadius: BorderRadius.circular(10.w),
            border: Border.all(width: 1,color: AppTheme.dividerColor2),
          ),
        ),
        dropdownStyleData: DropdownStyleData(
          width: null, // 跟随按钮宽度
          decoration: BoxDecoration(
            color: AppTheme.dividerColor,
            borderRadius: BorderRadius.circular(4),
          ),
          offset: const Offset(0, 0), // 默认正下方弹出
        ),
      ),
    );
  }
相关推荐
0wioiw010 小时前
Flutter基础(前端教程③-跳转)
前端·flutter
Lefan12 小时前
一文了解什么是Dart
前端·flutter·dart
0wioiw013 小时前
Flutter基础(前端教程④-组件拼接)
前端·flutter
木叶丸14 小时前
Flutter 生命周期完全指南
android·flutter·ios
用户74279877375914 小时前
[flutter翻书效果] 用flutter实现一个书籍翻页效果
flutter
技术蔡蔡21 小时前
Flutter和Firebae简单的聊天应用
flutter·全栈·firebase
小蜜蜂嗡嗡2 天前
flutter封装vlcplayer的控制器
前端·javascript·flutter
你听得到112 天前
从需求到封装:手把手带你打造一个高复用、可定制的Flutter日期选择器
前端·flutter
哲科软件2 天前
跨平台开发的抉择:Flutter vs 原生安卓(Kotlin)的优劣对比与选型建议
android·flutter·kotlin
天涯海风2 天前
Kuikly 与 Flutter 的全面对比分析,结合技术架构、性能、开发体验等核心维度
flutter·kuikly