javascript - Angular ui 路由器 : accessing $stateParams on reload

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

在我的 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(确保我的 Controller 再次启动)而不将其显示在 URL 上的最佳方法是什么?

最佳答案

在这种情况下,如果我们希望参数在页面重新加载(或在新选项卡/窗口中打开)后仍然存在,它们必须是 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

关于javascript - Angular ui 路由器 : accessing $stateParams on reload,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33064608/

相关文章:

javascript - 我如何在所有分辨率下将画廊垂直固定在中间

javascript - $scope.model 属性的配置未定义

javascript - 将选项值设置为数组

angularjs - Ui-sref 不在 URL 中生成哈希(Angular 1.3.0-rc.3)

javascript - 如何调试 jQuery/JavaScript 冲突?

javascript - 数组组合重复值

javascript - 测试嵌套 JavaScript 对象键是否存在

angularjs - 使用 Jest 对 AngularJS 指令进行单元测试

angularjs - 路由更改后销毁 Angular $http 成功/错误片段

angularjs - 在 uiRouter 中从子状态更改父 Controller 属性