Flutter Package系列 --- fpdart

fpdart 是 Dart 和 Flutter 中函数式编程的软件包。 fpdart 的目标是让开发人员能够在其应用程序中学习和使用函数式编程,提供了许多其他函数式语言开箱即用的所有主要函数式编程类型。

yaml 复制代码
# pubspec.yaml
dependencies: 
  fpdart: ^1.1.0

Option

使用Option 处理缺失值。您可以将类型定义为 Option ,而不是使用 null,会产生更佳简洁的写法

ini 复制代码
/// 一般对于null 的处理
const int? a = null;
int result = 0;
if (a != null) { 
   result = a * 2;
} 
/// 使用Option 对null 的处理
final Option<int> b = none<int>(); 
final result = b.getOrElse(() => 0) * 2;

当函数在某些边缘情况下无法返回值时,这非常有用。如果不想抛出异常(不建议抛出异常的做法),可以使用 Option

scss 复制代码
/// 抛出异常 Exception 方式
double divide(int x, int y) { 
  if (y == 0) { 、
    throw Exception('Cannot divide by 0!'); 
  } 
  return x / y;
} 
/// Option 方式
Option<double> divideF(int x, int y) {
  if (y == 0) { 
      return none(); 
  } 
  return some(x / y);
}

Either

使用Dartz 针对网络请求进行封装一文中我们也介绍了这个Either,这里也简单的说明一下。

Either 用于处理错误。 Either 可以是 RightLeft(不能两者兼而有之!)。 Right 包含函数成功时返回的值,Left 包含函数失败时的一些错误或消息。

arduino 复制代码
/// 抛出异常的做法 
double divide(int x, int y) { 
   if (y == 0) { 
      throw Exception('Cannot divide by 0!'); 
   } 
   return x / y;
} 
/// Error 的做法
Either<String, double> divide(int x, int y) { 
   if (y == 0) { 
       return left('Cannot divide by 0'); 
   }
   return right(x / y);
 }

Task

Task允许您以更可组合的方式运行异步函数:

正常的异步

javascript 复制代码
/// 一般做法
Future<int> async() { 
   return Future.value(10).then((value) => value * 10);
} 
/// Task 做法
Task<int> asyncF() { 
  return Task(() async => 10).map((a) => a * 10);
}

发生异常的异步

对于可能出现异常的情况,可以使用下面的做法。

dart 复制代码
/// catchError 的做法
Future<int> async() { 
   return Future<int>.error('Some error!') .then((value) => value * 10)    
                      .catchError((dynamic error) => print(error));
} 
/// TaskEither 的做法
TaskEither<String, int> async() { 
return TaskEither<String, int>( () async => left('Some error'), ).map((r) => r * 10);
}

结尾

更多的使用方法,请查看一下链接pub.dev/packages/fp...

相关推荐
大怪v1 小时前
AI抢饭?前端佬:我要验牌!
前端·人工智能·程序员
新酱爱学习1 小时前
字节外包一年,我的技术成长之路
前端·程序员·年终总结
小兵张健1 小时前
开源 playwright-pool 会话池来了
前端·javascript·github
IT_陈寒4 小时前
Python开发者必知的5大性能陷阱:90%的人都踩过的坑!
前端·人工智能·后端
codingWhat4 小时前
介绍一个手势识别库——AlloyFinger
前端·javascript·vue.js
勤劳打代码4 小时前
Flutter 架构日记 — 状态管理
flutter·架构·前端框架
代码老中医4 小时前
2026年CSS彻底疯了:这6个新特性让我删掉了三分之一JS代码
前端
不会敲代码14 小时前
Zustand:轻量级状态管理,从入门到实践
前端·typescript
踩着两条虫4 小时前
VTJ.PRO 双向代码转换原理揭秘
前端·vue.js·人工智能
扉川川4 小时前
OpenClaw 架构解析:一个生产级 AI Agent 是如何设计的
前端·人工智能