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), // 默认正下方弹出
        ),
      ),
    );
  }
相关推荐
不爱吃糖的程序媛2 小时前
Flutter OH 框架介绍
flutter
ljt27249606612 小时前
Flutter笔记--加水印
笔记·flutter
恋猫de小郭5 小时前
2026,Android Compose 终于支持 Hot Reload 了,但是收费
android·前端·flutter
ljt27249606611 天前
Flutter笔记--事件处理
笔记·flutter
Feng-licong1 天前
告别手写 UI:当 Google Stitch 遇上 Flutter,2026 年的“Vibe Coding”开发流
flutter·ui
不爱吃糖的程序媛2 天前
Flutter OH Engine构建指导
flutter
小蜜蜂嗡嗡2 天前
flutter实现付费解锁内容的遮挡
android·flutter
tangweiguo030519872 天前
Flutter iOS 调试利器:idevicesyslog 从入门到精通
flutter
tangweiguo030519872 天前
Flutter 异常捕获与处理:从入门到生产实践
flutter
不爱吃糖的程序媛2 天前
已有 Flutter 应用适配鸿蒙平台指导文档
flutter·华为·harmonyos