账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    angualr的ui-router路由中的2个独立的state怎么互相嵌套
    59
    0
    $stateProvider
    .state("PageOne", {
        url: "/PageOne",
        templateUrl: "PageOne.html"
    })
    .state("PageTwo", {
        url:"/PageTwo",
        templateUrl: "PageTwo.html"
    });

    场景:
    pageOne中有很多子路由,然后其中有个子路由需要可以访问到pageTwo,比如一个管理菜单的界面,左侧是菜单树,右侧是具体模块内容,通常右侧的内容是数据pageOne的路由的子路由来加载,但是有些特殊的需求导致有些不是写到pageOne中而是写到pageTwo中,这样左侧点击菜单的时候右侧需要显示具体的内容就系统跳转到pageTwo,目前我的实现方式是通过iframe重新加载pageTwo,嵌套路由不知道怎么实现,欢迎讨论下。

    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 半夏° 普通会员 1楼

      在Angular中,可以通过使用ui-routerstateview组件来实现两个独立的state互相嵌套。下面是一个简单的例子:

      1. 首先,我们需要创建两个state,一个用于当前页面,另一个用于导航菜单。

      ```typescript export class CurrentPageState { constructor(private route: ActivatedRoute) {}

      navigate() { this.route.navigate(['/main']); } }

      export class MainPageState { constructor(private route: ActivatedRoute) {}

      navigate() { this.route.navigate(['/home']); } } ```

      1. 然后,我们可以使用stateview组件来显示这两个state。

      ```typescript export class App { constructor(private router: Router, private currentPage: CurrentPageState, private mainPage: MainPageState) {}

      ngOnInit() { this.currentPage.navigate(); this.mainPage.navigate(); } } ```

      在这个例子中,我们创建了两个stateCurrentPageStateMainPageState。然后,我们创建了一个App组件,它包含了这两个state

      App组件的ngOnInit方法中,我们使用this.currentPage.navigate()this.mainPage.navigate()方法来导航到这两个state。这将使App组件显示这两个state

      注意,每个state都有自己的路由,所以它们的navigate()方法都需要传入对应的路由。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部