typescript - 如何将 RxJs 6 与 TypeScript 和 WebPack 一起使用

标签 typescript rxjs rxjs6

我遵循了本教程(非常简单): https://www.techiediaries.com/rxjs-tutorial/

我的 index.ts 看起来像这样:

import { Observable, Observer } from "rxjs";
import { map } from "rxjs/operators"

console.log(Observable);

var observable = Observable.create((observer:Observer<string>) => {
    observer.next('Hello');
    observer.next('Hello Again');
    observer.complete();
});

observable.map((s:string) => s).subscribe((x:any) => {
    console.log(x);
});

webpack-dev-server 启动没有问题。似乎“Observable.create”也有效。

我的问题:没有一个运算符(operator)可以工作。打开页面时出现错误:

Uncaught TypeError: observable.map is not a function

我现在搜索了 2 个小时 - 每篇文章都解释说这应该是将 RxJs 6 与 TypeScript 结合使用的正确方法。

我的 tsconfig.json:

{
  "compilerOptions": {
    "outDir": "./dist/",
    "sourceMap": true,
    "noImplicitAny": true,
    "module": "es6",
    "moduleResolution": "node",
    "target": "es6",
    "allowJs": true,
    "typeRoots": [
      "node_modules/@types"
    ],
    "lib": [
      "es2017",
      "dom"
    ]
  }
}

我的 webpack.config.js:

const path = require('path');
module.exports = {
    entry: './src/index.ts',
    devtool: 'inline-source-map',
    module: {
      rules: [
        {
          test: /\.tsx?$/,
          use: 'ts-loader',
          exclude: /node_modules/
        }
      ]
    },
    resolve: {
      extensions: [ '.tsx', '.ts', '.js' ]
    },
    output: {
      filename: 'bundle.js',
      path: path.resolve(__dirname, 'dist')
    }
};

最佳答案

因为您使用的是运算符的旧语法。当前的一个包括使用 pipeable operators :

import { Observable, Observer } from "rxjs";
import { map } from "rxjs/operators"

console.log(Observable);

var observable = Observable.create((observer:Observer<string>) => {
    observer.next('Hello');
    observer.next('Hello Again');
    observer.complete();
});

observable.pipe(
  map(s => s.toLowercase())
).subscribe(s => console.log(s));

注意:您的 map 没有做任何有用的事情,所以我让它做了一些事情。使用 any 确实是个坏主意,所以除了使用类型推断之外,我也删除了它。

关于typescript - 如何将 RxJs 6 与 TypeScript 和 WebPack 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53359370/

相关文章:

javascript - 无法访问使用 React.lazy 导入的组件的静态属性

javascript - 无需在调用类中订阅即可获取可观察的返回值

typescript - 连接 rxjs Observables

reactjs - 如何创建接受泛型的无状态功能组件?

html - TypeScript 错误 - 此条件将始终返回 'false',因为类型 'boolean' 和 'string' 没有重叠

rxjs - 减少返回空数组,但扫描不返回

Angular6 属性 'debounceTime' 在 'Observable<any>' 类型上不存在?

javascript - 如何使用 rxjs 的 sum 运算符?

angular - 在 RxJS 6 和 Angular 6 出现错误后如何保持可观察性

javascript - rxjs 可观察管道内的建模和 if/else 模式