0

我有一个当前运行 4 个网格的页面。与页面一起加载的主网格是用户,然后在一个 Modal 中加载了另外 3 个网格,每个网格都在它自己的选项卡中。我一直遇到的问题是,当我在模态中添加第 4 个、第 3 个时,其他两个或最后一个将不会呈现。我得到了网格轮廓,但没有数据。每次我加载模态时,都会随机发生这种情况。

我的 gridOptions 看起来像这样:

` $scope.gridOptionsAdd = {
    enableColumnResizing: true,
    enableSorting: true,
    data: $scope.newAdd,
    columnDefs: [
      {name: 'Address Type', field: 'addressTypeDescription'},
      {name: 'Data', field: 'addressData'},
      {name: 'Primary', field: 'primaryYn'},
      {name: 'Private', field: 'privateYn'},
      {name: 'Remove', cellTemplate: ' ' +
        '<button type="button" class="usrView btn btn-danger btn-sm" ng-click="grid.appScope.groupRemove(row.entity.id)">' +
        '<div class="fa fa-trash" data-toggle="tooltip" data-pacement="bottom" title="View User"></div>' +
        '</button>'
      }
    ],
    onRegisterApi: (gridApi) ->
      $scope.gridApiAdd = gridApi
      $interval( () ->
        $scope.gridApi.core.handleWindowResize()
      , 500, 10)
  }`

除了 ; 中的第三个变量外,3 个网格中的每一个都是相同的代码$interval;它们是 10、18 和 26。模态代码是这样的:

` #open edit user modal
  $scope.userEdit = (id) ->
    $scope.userId = id
    $modalInstance = $uibModal.open ({
      animation: $scope.animationsEnabled,
      templateUrl: 'userEditModal.html',
      controller: 'editUserInCtrl',
      keyboard: true,
      size: 'lg',
      scope: $scope,
      resolve: {
        data: () ->
          return  EntryUsr.get({id: id }).$promise
        ,
        address: () ->
          return EntryAdd.query({user_id: id}).$promise
        ,
        addType: () ->
          return EntryAddType.query().$promise
        ,
        usrPosition: () ->
          return EntryPos.query().$promise
      }
    })
    $scope.updateGrpTable()
    $scope.updateRoleTable()
    $scope.updateAddTable()`

最后 3 次调用拉取用户组、安全设置和地址并将它们写入网格;$scope.gridOptionsAdd.data = data.

网格在 HTML 中定义为:

 %div.grid#grid3{'ui-grid'=>'gridOptionsRole'}

每个网格都有自己的 ID,并引用不同的 gridOption 集

我的控制台中什么也没有,除了 3 个错误提示它可以读取属性“核心”

angular.self-a3680ff….js?body=1:13643 TypeError: Cannot read property 'core' of undefined
    at user.self-2a6c9f3….js?body=1:200
    at callback (angular.self-a3680ff….js?body=1:12457)
    at Scope.$eval (angular.self-a3680ff….js?body=1:17379)
    at Scope.$digest (angular.self-a3680ff….js?body=1:17192)
    at Scope.$apply (angular.self-a3680ff….js?body=1:17487)
    at tick (angular.self-a3680ff….js?body=1:12447)

非常感谢。

4

1 回答 1

0

我遇到的问题与这张票有关5151。因为在模态中存在问题的网格与 Angulars 显示功能来解决此问题,所以 gridOptions 调用更改为:

$scope.gridOptionsAdd = {
    enableColumnResizing: true,
    enableSorting: true,
    data: $scope.newAdd,
    columnDefs: [
      {name: 'Address Type', field: 'addressTypeDescription'},
      {name: 'Data', field: 'addressData'},
      {name: 'Primary', field: 'primaryYn'},
      {name: 'Private', field: 'privateYn'},
      {name: 'Remove', cellTemplate: ' ' +
        '<button type="button" class="usrView btn btn-danger btn-sm" ng-click="grid.appScope.groupRemove(row.entity.id)">' +
        '<div class="fa fa-trash" data-toggle="tooltip" data-pacement="bottom" title="View User"></div>' +
        '</button>'
      }
    ]
  }

在我的 application.js 文件中,ui.grid.autoResize添加了:

angular.module('myApp', [
                            "ngResource",
                            "ui.bootstrap",
                            "ui.grid",
                            "ngFileUpload",
                            "ui.grid.autoResize"
                        ]);

HAML 模板我添加了ui-grid-auto-resize标签

%div.grid#grid4{'ui-grid'=>'gridOptionsAdd', 'ui-grid-auto-resize'=>''}
于 2016-08-12T21:29:06.433 回答