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

相关推荐
蒋星熠4 小时前
Flutter跨平台工程实践与原理透视:从渲染引擎到高质产物
开发语言·python·算法·flutter·设计模式·性能优化·硬件工程
卢叁7 小时前
Flutter之自定义TabIndicator
前端·flutter
萧雾宇8 小时前
Android Compose打造仿现实逼真的烟花特效
android·flutter·kotlin
拜无忧9 小时前
【教程】flutter常用知识点总结-针对小白
android·flutter·android studio
拜无忧10 小时前
【教程】Flutter 高性能项目架构创建指南:从入门到高性能架构
android·flutter·android studio
醉过才知酒浓10 小时前
flutter 拦截返回按钮的方法(WillPopScope or PopScope)
flutter
傅里叶12 小时前
sudo启动Flutter程序AMD初始化失败
linux·flutter
苦逼的搬砖工13 小时前
Flutter UI Components:闲来无事,设计整理了这几年来使用的UI组件库
前端·flutter
黑金IT14 小时前
Dart → `.exe`:Flutter 桌面与纯命令行双轨编译完全指南
flutter
iOS_MingXing15 小时前
flutter TabBar 设置isScrollable 第一个有间距
flutter