【问题标题】:Angular ui-router: accessing $stateParams on reloadAngular ui-router:重新加载时访问 $stateParams
【发布时间】:2016-01-08 22:58:29
【问题描述】:

在我的 Angular 应用中,我有这样的路由结构:

.state('mapping', {
    url: '/mapping',
    templateUrl: 'app/components/mapping/mapping.html',
    controller: 'MapCtrl as map',
    abstract: true,
    authenticate: true
})
.state('mapping.all', {
    url: '',
    templateUrl: 'app/components/mapping/partials/all.html',
    authenticate: true
})
.state('mapping.project', {
    url: '/:projectName',
    controller: 'ProjectCtrl as proj',
    templateUrl: 'app/components/mapping/partials/project.html',
    authenticate: true
})

预期的功能是,当用户访问'mapping.project' 时,应用程序将使用projectID 变量加载与该项目相关的所有相关信息,该变量使用ui-sref 通过$stateParams 传递(不可见):

ui-sref="mapping.project({projectId: project.id, projectName: project.name})"

但是这会导致不希望的行为:当用户在已经处于 'mapping.project' 状态时重新加载页面时,将不会加载任何内容,因为没有有效地传递 $stateParams

在重新加载时获取projectId确保我的控制器再次启动)而不在 URL 上显示的最佳方法是什么?

【问题讨论】:

    标签: javascript angularjs angular-ui-router parameter-passing state


    【解决方案1】:

    在这种情况下,如果我们希望我们的参数在页面重新加载(或在新选项卡/窗口中打开)后仍然存在,那么它们只是 必须 成为 URL 的一部分。所以这样做的方法是用projectId扩展URL定义:

    .state('mapping.project', {
        url: '/:projectName?projectId',
        ...
    })
    

    这会将projectId 添加为“查询字符串参数”。另一种选择是 params 嵌套

    .state('mapping.project', {
        url: '/:projectName/:projectId',
        ...
    })
    

    还要检查这个:How to pass parameters using ui-sref in ui-router to controller

    【讨论】:

    • 我不知道,我认为不可见地传递 $stateParams 会按预期工作。谢谢!
    • 它根本做不到,因为它在我们的 SPA 中通过 Javascript 传递参数。重新加载或在新窗口中打开 === 只保留 url 部分
    猜你喜欢
    • 2018-06-04
    • 2014-11-18
    • 2016-02-08
    • 2014-05-29
    • 2015-12-12
    • 1970-01-01
    • 2016-04-28
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多