angularjs – $stateParams返回undefined

前端之家收集整理的这篇文章主要介绍了angularjs – $stateParams返回undefined前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我定义了这些路线:
.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,即使我认为我在路由中定义了它.
为什么会这样?

谢谢你的帮助!

@H_502_12@
@H_502_12@
当您访问URL / sport / 12时,SportCtrl将被实例化两次:一次用于状态运动,一次用于状态sport.selected.对于第一个状态,没有与状态相关的参数,因此$stateParams.sport是未定义的.

请注意,对状态和子状态使用相同的模板是很奇怪的.您将在同一模板的ui-view div中嵌入模板.

@H_502_12@ 原文链接:https://www.f2er.com/angularjs/141348.html

猜你在找的Angularjs相关文章