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

相关推荐
前端开发熊3 分钟前
实时薪资追踪-每秒都让收入看得见的 Chrome 扩展,你还不来试试?
前端
bnnnnnnnn5 分钟前
看完就懂、懂完就敢讲的「原型与原型链」终极八卦!
前端·javascript·面试
zacksleo7 分钟前
哪些鸿蒙原生应用在使用Flutter
前端·flutter·harmonyos
水煮白菜王8 分钟前
Nginx攻略
前端·nginx
難釋懷15 分钟前
Vue非单文件组件
前端·vue.js
恰薯条的屑海鸥29 分钟前
零基础学前端-传统前端开发(第三期-CSS介绍与应用)
前端·css·学习·css3·前端开发·前端入门·前端教程
海盐泡泡龟31 分钟前
盒模型小全
前端·css·盒模型
OpenTiny社区41 分钟前
HDC2025即将拉开序幕!OpenTiny重新定义前端智能化解决方案~
前端·vue.js·github
奇舞精选44 分钟前
前端开发中AI的进阶之路:从思维重构到工程落地
前端·人工智能