首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rxjs发行的Redux可观察史诗

Rxjs发行的Redux可观察史诗
EN

Stack Overflow用户
提问于 2019-08-01 15:16:00
回答 2查看 374关注 0票数 1

我的史诗如下

代码语言:javascript
复制
export const fetchSomethingEpic = (action$, state$) => {
  return action$.pipe(ofType(someActions.FETCH_LEADS),
    mergeMap(action =>
      from(api().get('SOMETHING'))
        .map(response => fetchSomethingSuccess(response.data))
        .catch(error => Observable.of(fetchSomethingError(error))))
  );
}

这里是axios.create,它发生在另一个文件中。

基本上,当我安装rxjs-compat时,这是非常完美的。但是试图删除它,现在给了我以下错误

代码语言:javascript
复制
TypeError: Object(...)(...).map is not a function

在安装了rxjs-compat之后,它就在哪里工作

我有

代码语言:javascript
复制
import { Observable } from 'rxjs/Rx';
import { mergeMap } from 'rxjs/operators';

  "rxjs": "6.2.1",
  "rxjs-compat":"6.2.1"

现在我有了

代码语言:javascript
复制
  import { Observable } from 'rxjs'
  import { mergeMap, map} from 'rxjs/operators';

 "rxjs": "^6.5.2"

我是不是漏掉了什么

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-08-07 09:03:48

按以下方式解决

代码语言:javascript
复制
  export const fetchSomethingEpic = (action$) =>
      action$.ofType(someActions.FETCH_LEADS)
        .pipe(mergeMap((action) => from(api().get('SOMETHING'))
          .pipe(map(response => fetchSomethingSuccess(response.data)),
            catchError(error => fetchSomethingError(error))))
        );
票数 0
EN

Stack Overflow用户

发布于 2019-08-06 03:36:32

您必须使用pipe传递可观察到的使用map运算符。还导入catchError以处理错误。

代码语言:javascript
复制
export const fetchSomethingEpic = (action$, state$) => {
  return action$.pipe(ofType(someActions.FETCH_LEADS),
    mergeMap(action =>
      from(api().get('SOMETHING'))
        .pipe(map(response => fetchSomethingSuccess(response.data)),
        catchError(error => Observable.of(fetchSomethingError(error))))
  );
}
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57312163

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档