gpt4 book ai didi

typescript - angular2 CLI 项目中缺少一些 RxJS 运算符?该怎么办?

转载 作者:太空狗 更新时间:2023-10-29 18:17:07 24 4
gpt4 key购买 nike

我正在学习 RxJS,我不断尝试许多我觉得有趣的运算符和组合。

我在这里学习表格:http://reactivex.io/documentation/operators.htmlhere .

我有一个 Angular2 rc4 CLI 项目 - 所以我使用的是 Typescript。 RxJS 是:5.0.0-beta.6

问题:

我发现 Observable 上没有一些运算符。

例如:我想创建一个可观察对象,它返回一个对象的一对一键值对:你可以看到实现的样子,正如我所接受的那样from here .

// Using Standard JavaScript
var obj = {
foo: 42,
bar: 56,
baz: 78
};

var source = Rx.Observable.pairs(obj);

var subscription = source.subscribe(
function (x) {
console.log('Next: %s', x);
},
function (err) {
console.log('Error: %s', err);
},
function () {
console.log('Completed');
});

// => Next: ['foo', 42]
// => Next: ['bar', 56]
// => Next: ['baz', 78]
// => Completed

但这是我的编辑器的样子:

enter image description here

Observable.pairs() 没有 Intelisense..

enter image description here

基于 this post我添加了 2 个导入:

import {Observable} from "rxjs/Rx";
import 'rxjs/Rx'; // import all operators and stuff. it's not good practice i know, but only for this example

并尝试为 rxjs 安装比 angular cli 提供的更多的类型,但没有工作:

typings install --save --ambient npm:rx/ts/rx.all.d.ts // Unable to resolve "npm:rx/ts/rx.all.d.ts" from "rx"
or
typings install rxjs // Unable to find "rxjs" ("npm") in the registry.

并且还尝试使用:

import * as Rx form 'rxjs/Rx'
myObjProperties$ = Rx.Observable.pairs(myObj) // still doesn't work, same error.

此外,我无法解释为什么无法将 Observable 对象打印到控制台。我得到了一个无用的 string-function。没有原型(prototype)的东西。

console.log('TheAllmightyObservable : ', Observable) // i get:

// TheAllmightyObservable : function Observable(subscribe) {
// this._isScalar = false;
// if (subscribe) {
// this._subscribe = subscribe;
// }
// }

我有与许多其他运算符相同的问题:ofObjectChanges、ofArrayChanges、ofWithSkeduler、pairs——其中一些不是那么重要——但当我发现一个非常有用的 RxJs 运算符时,它让我很烦恼,我不能在 angular2 CLI 项目中使用它。

问题:

  1. angular2 与 RxJS 有什么关系? (我想我错过了一般图片..) - 是否有一个单独的 angular2-rxjs 运算符列表或 RxJS 是完全独立的包,并且可以像 Jquery 一样使用?我的意思是两者之间没有有线干扰——我无法预测。 (可能与摘要周期有关?!)

  2. 我在哪里可以找到 angular2 上可用的所有 RxJS 运算符的良好列表 - 假设存在。

  3. 这只是一个 Typescript - 打字问题吗?如果是这样,如何安装它们以便拥有文档中可用的所有运算符?如果没有可用的类型,如何暂时摆脱这个“no property/method found on x”问题?

非常感谢您花时间阅读并帮助我找到解决方案:)

最佳答案

根本问题:您正在使用一个版本的 RxJS,但正在查看另一个版本的文档。

与 Angular 2 一起使用的 RxJS 5(测试版):https://github.com/ReactiveX/rxjsRxJS 4(稳定):https://github.com/Reactive-Extensions/RxJS

这些运算符在新版本中不存在,这就是您看不到它们的原因。

您的问题:

1) RxJS 与 Angular2 没有任何关系,你可以在没有 Angular2 的情况下使用 RxJS。 RxJS 只是一个用于创建事件流的库,它与您用来生成 事件的东西正交运行。

2) 如果您使用的是 RxJS 4,那么您可以使用 docs这是相当不错的。 RxJS 5 仍在进行中,但构建过程会生成文档 here .

3) 在这种情况下,这不是打字问题。

关于typescript - angular2 CLI 项目中缺少一些 RxJS 运算符?该怎么办?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38658582/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com