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...

相关推荐
辰同学ovo1 分钟前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
陈随易23 分钟前
2年没用Nodejs了,Bun很香
前端·后端·程序员
donecoding38 分钟前
Corepack 完全解析:从懵到懂,包管理器自由了
前端·node.js·前端工程化
yqcoder42 分钟前
端经典面试题:为什么 0.1 + 0.2 !== 0.3?
前端·css
ZC跨境爬虫1 小时前
跟着 MDN 学 HTML day_12:(HTML网页图片嵌入)
前端·javascript·css·ui·html
光影少年1 小时前
reeact虚拟DOM、Diff算法原理、key的作用与为什么不能用index
前端·react.js·掘金·金石计划
用户059540174461 小时前
大模型记忆存储踩坑实录:LangChain 的 ConversationBufferMemory 让我排查了 6 小时
前端·css
是上好佳佳佳呀1 小时前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
你真的快乐吗1 小时前
@fuxishi/svg-icon:一个 Vue 3 svg本地图标+iconify图标组件库,让图标管理不再头疼
前端·vue.js·typescript
Rkgua1 小时前
ESModule和Commonjs模块的区别
前端·javascript