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), // 默认正下方弹出
        ),
      ),
    );
  }
相关推荐
风华圆舞14 小时前
在 Flutter 鸿蒙项目里接入语音识别的完整思路
flutter·语音识别·harmonyos
风华圆舞16 小时前
鸿蒙 + Flutter 下如何让 HarmonyOS 能力真正服务于 AI 体验
人工智能·flutter·harmonyos
BreezeDove17 小时前
【Android】Flutter3.35项目启动超时问题
android·flutter
风华圆舞18 小时前
鸿蒙 MICROPHONE 权限在 Flutter 项目里怎么处理
flutter·华为·harmonyos
愚者Pro1 天前
切换本地 Flutter SDK 版本
flutter
TT_Close1 天前
别再复制旧 Flutter 工程了,真正拖慢你的不是业务代码
flutter·npm·visual studio code
风华圆舞1 天前
鸿蒙 + Flutter 下 AI 助手为什么要支持流式输出
人工智能·flutter·harmonyos
风华圆舞2 天前
鸿蒙 + Flutter 下 AI 页面的状态协同设计
人工智能·flutter·harmonyos
风华圆舞2 天前
鸿蒙语音播报功能 的 Flutter 侧封装思路
flutter·华为·harmonyos
brycegao3212 天前
Flutter 国际化富文本解决方案:基于双层占位符的轻量化图文混排方案
flutter·国际化·i18n·富文本·rtl·移动端工程架构