flutter中枚举的使用

Dart 2.17 增加了对枚举成员变量的支持,推荐使用方式三

使用dart工具来运行代码,工具:https://dartpad.cn

Dart 复制代码
//方式一:未支持扩展枚举时
enum InOutOrderStatusEnum {
  approval,
  completed,
  cancel,
  rejected;

  int get statusCode {
    switch (this) {
      case InOutOrderStatusEnum.approval:
        return 1;

      case InOutOrderStatusEnum.completed:
        return 2;
      case InOutOrderStatusEnum.cancel:
        return 3;

      case InOutOrderStatusEnum.rejected:
        return 4;
    }
  }

  String get statusName {
    switch (this) {
      case InOutOrderStatusEnum.approval:
        return "审批中";

      case InOutOrderStatusEnum.completed:
        return "已完成";
      case InOutOrderStatusEnum.cancel:
        return "已撤销";

      case InOutOrderStatusEnum.rejected:
        return "已拒绝";
    }
  }
}

//方式二:使用extension对方式一进行优化
enum InOutOrderStatusEnum1 {
  approval,
  completed,
  cancel,
  rejected,
}

extension InOutOrderStatusEnumExtension on InOutOrderStatusEnum1 {
  int get statusCode => index + 1;
  String get statusName => ["审批中", "已完成", "已撤销", "已拒绝"][index];
}

//方式三:Dart 2.17 增加了对枚举成员变量的支持
enum InOutOrderStatusEnum2 {
  approval(1, "审批中"),
  completed(2, "已完成"),
  cancel(3, "已撤销"),
  rejected(4, "已拒绝");

  final int statusCode;
  final String statusName;
  const InOutOrderStatusEnum2(this.statusCode, this.statusName);
//想要支持从枚举转换为 String,我们可以很简单地覆写 toString 方法,因为 enums 也继承自 Object
  @override
  String toString() => 'the $name InOutOrderStatusEnum2 is $statusName';
}

void main() {
  final status = InOutOrderStatusEnum.approval;

  print(
      'statusIndex:${status.index},\n statusCode:${status.statusCode},statusName:${status.statusName}');

  final status1 = InOutOrderStatusEnum1.approval;

  print(
      'statusIndex1:${status1.index},\n statusCode1:${status1.statusCode},statusName1:${status1.statusName}');

  final status2 = InOutOrderStatusEnum2.approval;

  print(
      'status2:$status2,\n statusCode2:${status2.statusCode},statusName2:${status2.statusName}');
}

运行结果:

参考:Dart(15)-枚举_dart enum-CSDN博客

相关推荐
xmdy58662 小时前
Flutter+开源鸿蒙全域智慧泊车调度管理平台 Day4 订单全流程闭环+支付核验+会员权益+个人中心开发
flutter·开源·harmonyos
W蘭2 小时前
Flutter从入门到实战-01-Dart语言基础
flutter
xuankuxiaoyao3 小时前
Vue.js 插槽、作用域插槽、商品、阶段案例
android·vue.js·flutter
恋猫de小郭3 小时前
终于,Flutter 修复 Android 中文字体异常,但是很草台,不知怎么吐槽
android·前端·flutter
xmdy58663 小时前
Flutter + 开源鸿蒙跨端实战|基于空间地理信息的城市全域智慧泊车调度与多维运维管理平台 Day3
flutter·华为·开源
UnicornDev3 小时前
【Flutter x HarmonyOS 6】魔方计时APP——挑战页面的UI设计
flutter·ui·华为·harmonyos·鸿蒙
张风捷特烈4 小时前
状态管理大乱斗#08 | MobX 源码评析 - 透明魔法
android·前端·flutter
西西学代码6 小时前
Flutter---RichText(混合文本样式)
flutter
西西学代码6 小时前
Flutter---PageView
flutter
wuxianda103020 小时前
uniapp项目上架苹果商店4.3a被拒,3天极速解决方案2026.5.8
前端·人工智能·flutter·uni-app·ios上架·苹果上架·苹果4.3a