- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 ngrx 和 Redux 风格架构的新手,我在理解应该如何链接操作/效果时遇到问题。一个例子是实现基本功能,例如在用户登录后采取行动。我在这里的核心问题是,在用户登录后要采取的行动将根据应用程序的当前状态而有所不同——用户可能在任何地方在出现登录提示/页面时出现在应用程序中。
我见过的任何示例都会在用户登录后发生硬编码效果。在我的场景中,这并不适合如上所述,我并不总是希望发生相同的操作。
以下是包含登录组件的主页的一些示例代码。在这种情况下,我希望用户在登录后被重定向到“/buy”。
@Component(..)
export class HomePageComponent {
constructor(private store: Store<any>) {
}
public onLoginSubmitted(username, password) {
this.store.dispatch(new loginActions.Login({username, password}));
// once this has happened successfully navigate to /buy
}
}
示例效果
@Injectable()
export class LoginEffects {
......
@Effect()
login$ = this.actions$
.ofType(loginActions.ActionTypes.LOGIN)
.switchMap((data) => {
return this.loginService.login(data.payload)
.map(() => new loginActions.LoginSuccess({loggedIn: true, isLoggingIn: false}))
.catch((error) => {
return of(new loginActions.LoginError({loggedIn: false, isLoggingIn: false}));
});
});
......
}
关于您如何解决这个问题,我有几个想法 - 但没有一个是正确的。这些包括
任何人都可以指出正确的道路/举例说明应该如何解决这个问题吗?
最佳答案
使用 mergeMap
对一组 Action ,一个效果可以触发多个 Action 。我通常会做的是,传递我希望登录效果也分派(dispatch)的附加操作。
@Component(..)
export class HomePageComponent {
constructor(private store: Store<any>) { }
public onLoginSubmitted(username, password) {
this.store.dispatch(new loginActions.Login({
username,
password,
onCompleteActions: [new loginActions.Redirect({ route: '/buy' })] }));
}
}
然后,登录效果将使用 mergeMap
分派(dispatch)任何传入的操作。您仍然需要为每个操作创建效果,但现在您可以构建更多可重复使用的操作,例如重定向操作。
@Injectable()
export class LoginEffects {
......
@Effect()
login$ = this.actions$
.ofType(loginActions.ActionTypes.LOGIN)
.switchMap((data) => {
let mappedActions = [new loginActions.LoginSuccess({loggedIn: true, isLoggingIn: false})];
if (data.payload.onCompleteActions)
mappedActions = mappedActions.concat(data.payload.onCompleteActions);
return this.loginService.login(data.payload)
.mergeMap(mappedActions)
.catch((error) => {
return of(new loginActions.LoginError({loggedIn: false, isLoggingIn: false}));
});
});
......
}
我喜欢这个解决方案的一点是它可以扩展到 future ,因为可以传入任何操作,并且没有开关或 if-else 树来决定要做什么。您还可以传入多个操作,因此无需构建“redirectAndCloseModal”操作,您可以传入 redirect
以及 closeModal
。
this.store.dispatch(new loginActions.Login({
username,
password,
onCompleteActions: [new loginActions.Redirect({ route: '/buy' }), new modalActions.CloseModal()] }));
您可以阅读更多关于 dispatching multiple Actions from one @Effect() at this github issue. 的内容
编辑:关于您的评论,不仅仅是路由更改可能会让您想要停止登录,它可能是任何东西,例如关闭模式,并且没有通用的方法来监视那。您可以向您的商店添加一些东西,例如 runLoginActions
bool 值,然后在登录请求返回后从您的商店中读取该数据。
然后在您的 login$
效果中,您可以从商店中读取它来决定是否运行其他操作。
@Effect()
login$: Observable<Action> = this.actions$
.ofType(auth.actionTypes.LOGIN)
.map((action: auth.LoginAction) => action.payload)
.switchMap((user) => {
let successAction = new loginActions.LoginSuccess({loggedIn: true, isLoggingIn: false});
let mappedActions = [successAction];
if (data.payload.onCompleteAction)
mappedActions.push(data.payload.onCompleteAction);
return this.authService.login(user.username, user.password)
.withLatestFrom(this.store)
.mergeMap(([result, store]) => store.runLoginActions ?
[mappedActions] :
[successAction]
)
.catch((err) => {
try {
return of(new auth.NetworkFailureAction(err[0].code));
} catch (e) {
throw `Array not in the expected format of [{ code: "", message: "" }]`;
}
});
});
请注意,在你的 loginSuccess
reducer 中,你应该设置你的 runLoginActions = true
,它应该默认为 true,只有在路由时才关闭被更改,或者组件被销毁。
请记住,这是一个通用的解决方案,您将需要自己添加操作、更新您的 reducer 等。
这更像是一个手动过程,但由于您不想执行操作的情况非常具体,因此可能必须以这种方式完成。
关于angular - ngrx 链接 Action /效果 - 例如登录然后导航,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42373191/
我可以使用 javascript 和其他所有东西,但在重新发明轮子之前,我想知道是否已经有一个类似的 jquery 插件,因为我想使用那个框架而不是 mootools。 我没有钱的问题,特别是 5 欧
我正在 React 应用程序中处理动画。我需要动画在悬停 后开始工作。我尝试了 :hover:after css 但不起作用。将鼠标悬停在图像上后动画可以工作,但我需要在悬停后开始。将鼠标悬停在图像上
我正在使用 jQuery 在按钮单击时实现 slider 效果。我的代码是: $(document).ready(function() { $("#mybutton").click(functio
我需要一个div标签在屏幕右侧滑出,如何使用jQuery获得这种效果?我一直在看这里:http://api.jquery.com/category/effects/sliding/而且这似乎不是我要找
我正在使用此代码实现页面 curl 效果......它在模拟器和设备中工作正常......但它不是(setType:@“pageCurl”)苹果记录的api,这导致它被iPhone拒绝App Stor
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我见过各种关于 WPF 效果的引用,但它们似乎是针对位图的,而不是针对文本的。是否可以将除模糊或投影以外的效果应用于XAML中的TextBlock对象? 我想要做的示例可能是轮廓笔划,或斜角/浮雕效果
我正在尝试模拟这种效果:http://meyerweb.com/eric/css/edge/complexspiral/demo.html在我的博客上:http://segment6.blogspot
我尝试将样式应用到 Accordion Pane ,但遇到了问题。 这行不通。 accordion.setEffect(new DropShadow(BlurType.ONE_PASS_BOX, Co
关于 Datatables website 的教程足够清楚了: 在我告诉 Datatables 我正在谈论哪一列后,我只需将切换按钮放入: column.visible( ! column.visib
我正在寻找 scratchOut 效果,随便叫它什么。 这是从前景中删除图像的效果,因此背景图像变得可见。 我曾尝试使用 jquery 插件重新创建此效果,但它并不像我希望的那样流畅。 有没有人有这种
本文实例讲述了android实现文字和图片混排(文字环绕图片)效果。分享给大家供大家参考,具体如下: 在平时我们做项目中,或许有要对一张图片或者某一个东西进行文字和图片说明,这时候要求排版美观,所
本文实例讲述了Javafx简单实现【我的电脑资源管理器】效果。分享给大家供大家参考。具体如下: 1. java代码: ?
我是 ngrx 的新手,正在尝试让我的 ngrx 商店的 @Effect 函数正常工作。下面的代码显示了如果我没有使用 ngrx 商店,服务是如何工作的。我首先调用 http.get 来获取列表,然后
基本上我搜索了很多,解决方案建议应用一些 PNG 掩码或不提供所需的解决方案。 我发现了什么。 ffmpeg -i main.mkv -i facecloseup.mkv -filter_compl
有关使用从商店中选择的状态的效果的 Ngrx 文档状态(没有双关语意) Note: For performance reasons, use a flattening operator like co
我有一个数据网格控件,我在其中使用名为 FastShadow 的自定义效果,它就像一个光晕。 我希望效果在其边界之外发光,这样很好,但是当我在顶部绘制另一个形状时,我不希望这个形状受到影响。在本例中,
除了子 div.exception 中的所有内容,我想将 div.main 中的所有文本设为灰色。 div.exception 应该看起来好像类 main 从未添加到父 div。 这可能吗?如果是这样
我有一个 PDF 文件,我想重现此包页面中的页面 curl 效果: https://pub.flutter-io.cn/packages/page_turn 我试过用这个 page_turn插件,它需
我想测试一个效果如下: 如果调度了 LoadEntriesSucces 操作,则效果开始 等待 5 秒 5 秒后发送 http 请求 当响应到达时,将分派(dispatch)新的操作(取决于响应是成功
我是一名优秀的程序员,十分优秀!