javascript - Angular ,项目详细信息

标签 javascript angularjs

我正在学习 Angular (使用 ionic 框架,包括电话间隙),我正在尝试创建一个列出一些数据的应用程序,当您单击一个应用程序时,它会显示其详细信息。我能够列出所有项目,但无法管理如何显示单个项目的详细信息。我知道这个问题可能与 $routeParams 有关,但我找不到问题所在。

app.js

angular.module('app', ['ionic', 'app.controllers'])

.config(function($stateProvider, $urlRouterProvider, $routeProvider) {

    .state('app.list', {
      url: '/list',
      views: {
        'menuContent' :{
          templateUrl: "templates/list.html"
        }
      }
    })

    .state('app.staff', {
      url: '/staff/:staffid',
      views: {
        'menuContent' :{
          templateUrl: "templates/staff-details.html",
          controller: 'StaffDetailsCtrl'
        },
      }
    })

});

Controller .js

.controller('FooCtrl', function($scope) {
   $scope.staff = [
       { id: 1, name: 'Jim', color: 'red' },
       { id: 2, name: 'Bob', color: 'blue' },
       { id: 3, name: 'Peter', color: 'yellow' }
       /*... etc... */
   ];
});

// Review Controller
.controller('StaffDetailsCtrl', function($scope, $routeParams) {

  // Get staff
  alert('yeeeees');
  var id = $routeParams.staffid;
  $scope.staff = $scope.staff.get(id);

});

员工详细信息.html

{{staff.id}}<br />
{{staff.name}}<br />
{{staff.color}}

更新

链接到Plunker .

最佳答案

如果您使用的是 Angular-ui-router,那么您应该注入(inject) $stateParams 而不是 $routeParams。所以你的代码将如下所示:

angular.module('app', ['ionic', 'app.controllers'])
    .config(function($stateProvider, $urlRouterProvider, $routeProvider) {

        $stateProvider
            .state('app.staff', {
                url: '/staff/:staffid',
                views: {
                    'menuContent' :{
                        templateUrl: "templates/staff-details.html",
                        controller: 'StaffDetailsCtrl'
                    },
                 }
            })
 });

// Review Controller
.controller('StaffDetailsCtrl', function($scope, $stateParams) {
     // Get staff
    alert('yeeeees');
    var id = $stateParams.staffid;
    $scope.staff = $scope.staff.get(id);
});

关于javascript - Angular ,项目详细信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24577242/

相关文章:

angularjs - angular2 中 angular.equals 的等价物

javascript - 包含 ng-model 和 ng-repeat 后切换开关不切换

javascript - "$injector:modulerr": throwing error for module name is not available but actually it is available

javascript - Highcharts ng 热图绘制线而不是框

javascript - 无法更新 Service、AngularJS 中的值

javascript - 显示数组中的至少一项在线项目

javascript - 我想使用 Angular js 根据特定的时间和日期在 ionic 中进行本地通知

javascript - Angular.js/Javascript : checking if an object is found in any of the elements of an array

javascript - v2 和 v3 Google Maps API 能否在同一页面中共存?

javascript - Tumblr 上的快速点赞按钮