我已经配置了以下 ui-router。
app.config(['$stateProvider', function ($stateProvider) {
$stateProvider
.state('global.editor', {
url: '/posts/editor/{id}',
templateUrl: '/htmls/editor.html',
controller: 'EditorCtrl',
resolve: {
post: ['$stateParams', 'codeService', function ($stateParams, codeService) {
return codeService.getPost($stateParams.id)
}]
}
}
.state('global.new', {
url: '/new',
templateUrl: '/htmls/editor.html',
controller: 'EditorCtrl'
})
.state('global.newTRUE', {
url: '/newTRUE',
templateUrl: '/htmls/editor.html',
controller: 'EditorCtrl'
})
.state('global.editor.panels', {
controller: 'PanelsCtrl',
params: { layout: 'horizontal' },
templateUrl: function (params) { return "/htmls/" + params.layout + '.html' }
}
}])
app.controller('EditorCtrl', ['$scope', '$state', function ($scope, $state) {
$scope.layout = "horizontal";
$scope.$watch('layout', function () {
$state.go('global.editor.panels', { layout: $scope.layout });
});
}]);
结果,浏览器中的https://localhost:3000/#/new导致(状态global.editor
,然后到)状态global.editor.panels
。
现在,我想添加一个参数connected
:
- 我不希望它显示在网址中
- 浏览器中的https://localhost:3000/#/new是 ,浏览器中的
connected
https :false
// localhost:3000/#/newTRUE是connected
true
connected
可以过去进入控制器EditorCtrl
和PanelsCtrl
connected
可以在 中resolve
使用global.editor
;理想情况下,我们可以根据 的值解析不同的对象connected
。
有谁知道如何做到这一点?