gpt4 book ai didi

react-router - 可以在 redux-observable 的史诗中以编程方式更改路线吗

转载 作者:行者123 更新时间:2023-12-01 03:19:30 25 4
gpt4 key购买 nike

我正在使用 redux-observable 并且在我的史诗中我正在使用 browserHistory.push 更改其中一些的路线。这是标准/良好做法吗?我的直觉告诉没有,但需要你的意见。除此之外,升级到 react-router 4 后,我无法访问 browserHistory 我该怎么做?

最佳答案

紧急调用 browserHistory.push()完全没问题。如果它适用于您的用例并且您不需要知道 reducer 中的路由更改,请继续!

也就是说,“纯粹”的方式是让你的史诗发出一个会导致路线改变的 Action 。这可以通过使用新的 react-router-redux 在 react-router v4 中完成。 ,取代 old one with the same name .

添加后,您可以使用提供的操作创建器:

import { push } from 'react-router-redux';

export const somethingEpic = action$ =>
action$.ofType(SOMETHING)
.switchMap(() => {
somethingLikeAjaxOrWhatever()
.mergeMap(response => Observable.of(
somethingFulfilled(response),
push('/success-page')
))
});

要清楚, push() replace() react-router-redux 中的等是 Action 创建者——也就是 Action 工厂。它们实际上不会自己改变路线,也不会产生任何副作用。它们返回一个需要以某种方式调度以改变路由的 Action 。

使用 Action 来表示路由更改意图的另一个好处是可测试性。您不再需要模拟历史 API,您只需断言史诗发出预期的 Action 即可。这被称为“作为数据的效果”,因为您的代码不会执行实际的副作用,您只需生成意图。

关于react-router - 可以在 redux-observable 的史诗中以编程方式更改路线吗,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46679349/

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