[关闭]
@Rays 2018-05-17T18:44:07.000000Z 字数 1394 阅读 2116

RxJS 6发布,改进了性能和模块化

JavaScript


摘要: RxJS团队宣布RxJS 6.0发布。6.0改进了模块化方法和平滑迁移性能、为简化升级而添加了反向兼容软件包,并为TypeScript用户提供了代码迁移。

作者: Dylan Schiemann

正文:

RxJS团队宣布RxJS 6.0发布。6.0改进了模块化方法和平滑迁移性能、为简化升级而添加了反向兼容软件包,并为TypeScript用户提供了代码迁移。

rxjs-compat软件包提供了一个版本间的兼容层,用于实现从RxJS 5到6的平滑迁移,

用户可以使用npm安装RxJS 6和兼容层,命令如下:

  1. npm install rxjs@6 rxjs-compat@6 --save

兼容层使代码无需更改即可升级到6。但如果开发人员想在部署到生产环境前降低RxJS源包的大小,还应于此后升级自身的源代码。

Angular 6用户也可受益于RxJS的Schematics。他们可以利用Angular 6提供的ng update机制在应用中自动安装rxjs-compat。

RxJS 6将模块导入路径重新组织为如下几类:

推荐RxJS的TypeScript用户使用rxjs-tslint,它有助于将版本5的导入路径重构为版本6。

RxJS 6的另一个显著改进,是将操作符转变为使用链式调用API。RxJS的前期版本中以对操作法原型打补丁的方式提供了链式调用,但这样的全局实现引入了一些挑战,包括对WebPack的摇树(tree-shaking)优化功能,以及对代码检查(linting)工具。

例如,下面给出的例子代码使用了RxJS 5:

  1. source
  2. .map(x => x + x)
  3. .mergeMap(n => of(n + 1, n + 2)
  4. .filter(x => x % 1 == 0)
  5. .scan((acc, x) => acc + x, 0)
  6. )
  7. .catch(err => of('error found'))
  8. .subscribe(printResult);

如果使用RxJS 6,那么代码变为:

  1. source.pipe(
  2. map(x => x + x),
  3. mergeMap(n => of(n + 1, n + 2).pipe(
  4. filter(x => x % 1 == 0),
  5. scan((acc, x) => acc + x, 0),
  6. )),
  7. catchError(err => of('error found')),
  8. ).subscribe(printResult);

近期,RxJS项目牵头人Ben Lesh也谈及了RxJS 6,并介绍了支持项目改进的动机所在。

RxJS是一种用于响应式编程的软件库,它使用Observable构建异步代码或基于回调的代码。RxJS中Observable部分的标准化工作已经启动,并有望作为未来JavaScript版本的组成部分。但是推进Observable建议仍未受其牵引。

RxJS使用Apache 2许可发布。更多信息,请访问RxJS网站。欢迎开发人员通过RxJS GitHub项目做出贡献。

查看英文原文: RxJS 6 Release Improves Performance and Modularity

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注