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博客

相关推荐
江上清风山间明月2 小时前
flutter bottomSheet 控件详解
android·flutter·底部导航·bottomsheet
yuanlaile18 小时前
纯Dart Flutter库适配HarmonyOS
flutter·华为·harmonyos·flutter开发鸿蒙·harmonyos教程
yuanlaile18 小时前
Flutter开发HarmonyOS 鸿蒙App的好处、能力以及把Flutter项目打包成鸿蒙应用
flutter·华为·harmonyos·flutter开发鸿蒙
zacksleo19 小时前
鸿蒙原生开发手记:04-一个完整元服务案例
flutter
jcLee952 天前
Flutter/Dart:使用日志模块Logger Easier
flutter·log4j·dart·logger
tmacfrank2 天前
Flutter 异步编程简述
flutter
tmacfrank2 天前
Flutter 基础知识总结
flutter
叫我菜菜就好2 天前
【Flutter_Web】Flutter编译Web第三篇(网络请求篇):dio如何改造方法,变成web之后数据如何处理
前端·网络·flutter
AiFlutter2 天前
Flutter-底部分享弹窗(showModalBottomSheet)
java·前端·flutter
m0_748247803 天前
Flutter Intl包使用指南:实现国际化和本地化
前端·javascript·flutter