@Rays
2018-05-17T18:44:07.000000Z
字数 1394
阅读 2116
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和兼容层,命令如下:
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:
source
.map(x => x + x)
.mergeMap(n => of(n + 1, n + 2)
.filter(x => x % 1 == 0)
.scan((acc, x) => acc + x, 0)
)
.catch(err => of('error found'))
.subscribe(printResult);
如果使用RxJS 6,那么代码变为:
source.pipe(
map(x => x + x),
mergeMap(n => of(n + 1, n + 2).pipe(
filter(x => x % 1 == 0),
scan((acc, x) => acc + x, 0),
)),
catchError(err => of('error found')),
).subscribe(printResult);
近期,RxJS项目牵头人Ben Lesh也谈及了RxJS 6,并介绍了支持项目改进的动机所在。
RxJS是一种用于响应式编程的软件库,它使用Observable构建异步代码或基于回调的代码。RxJS中Observable部分的标准化工作已经启动,并有望作为未来JavaScript版本的组成部分。但是推进Observable建议仍未受其牵引。
RxJS使用Apache 2许可发布。更多信息,请访问RxJS网站。欢迎开发人员通过RxJS GitHub项目做出贡献。