我定义了这些路线:
.state('sport',url: '/sport' templateUrl: '/templates/sport' controller: 'SportCtrl' ) .state('sport.selected' url: '/:sport' templateUrl: '/templates/sport' controller: 'SportCtrl' )
我让这个控制器试图使用sport.selected状态给出的运动参数.
angular.module('myApp') .controller('SportCtrl',['$scope','ParseService','$stateParams',function ($scope,ParseService,$stateParams) { var sportURL = $stateParams.sport; ... });
出于某种原因,当我在控制器中调用$stateParams.sport时,它返回undefined,即使我认为我在路由中定义了它.
为什么会这样?
谢谢你的帮助!
当您访问URL / sport / 12时,SportCtrl将被实例化两次:一次用于状态运动,一次用于状态sport.selected.对于第一个状态,没有与状态相关的参数,因此$stateParams.sport是未定义的.
请注意,对状态和子状态使用相同的模板是很奇怪的.您将在同一模板的ui-view div中嵌入模板.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。