首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >圆: window.history.back()和location.back()

圆: window.history.back()和location.back()
EN

Stack Overflow用户
提问于 2016-10-14 09:45:47
回答 2查看 2.1K关注 0票数 0

在我的角度应用程序中,我有一个视图和一个带有输入表单的编辑视图。问题是:

如果我使用浏览器的后退按钮window.history.back()或Angular2 fine 中的等效location.back(),它将正常工作。

但是,如果我连续(两次)触发浏览器的后退按钮window.history.back()或等效的location.back(),它将启动一个循环--即返回到初始站点。

对于相同的站点,另一个奇怪的行为是:

  1. 在视图中,我使用普通的this.router.navigate(‘/编辑’)编辑视图;
  2. location.back()返回到视图
  3. 我再次使用普通的this.router.navigate(‘/编辑’)的编辑视图;
  4. 现在,我必须触发三次location.back()才能返回视图。

历史似乎被破坏了。

有没有人知道这个问题会是什么。它是否可能与形式相关?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-10-14 20:00:53

不要多次导入路由

导出路由: ModuleWithProviders =RouterModule.forRoot(路由)

票数 0
EN

Stack Overflow用户

发布于 2016-10-24 21:53:41

在从rc4迁移到final的过程中,我遇到了同样的问题,下面是对我有用的方法。正如在previous answer上所述,您应该只使用RouterModule.forRoot()方法导出一次属于主应用程序模块的路由。

export const routing: ModuleWithProviders = RouterModule.forRoot(MainModuleRoutes);

但是,如果在主应用程序模块中导入了有自己路由的子模块,则应该使用RouterModule.forChild()将其导出为子路由。

export const routing: ModuleWithProviders = RouterModule.forChild(ChildModuleRoutes);

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40040042

复制
相关文章

相似问题

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