javascript - CellFilter 在 UI-Grid 中的 $http 响应之前被调用

标签 javascript angularjs angularjs-scope ui-grid angularjs-http

我正在使用 ui-grid 绑定(bind) Angular 色表中的数据,该表包含部门 ID 作为主键。我正在调用 Web Api 以获取表中的所有 Angular 色并显示在 ui-grid 中。

部门表

enter image description here

Angular 色表

enter image description here

我真正的问题是,当它使用 cellFilter 绑定(bind)到网格时,我想将部门 ID 转换为部门名称,这就是为什么我声明 objMapping 以将部门 ID 映射到部门名称。但是每次我运行时,我都会看到 cellFilter 自定义函数,即“mapDepartmentName”在设置 objMapping 之前被调用,而且我无法在“mapDepartmentName”中引用 objMapping。

我的网格看起来像这样:-

enter image description here

然而,当我编辑时,我得到的结果如下,这是绝对正确的:-

enter image description here

我的代码片段如下:-

var myApp = angular.module('appHome', ['ui.grid', 'ui.grid.edit']);
myApp.controller("ctrlRole", ['$scope', 'MetadataOrgFactory', function ($scope, MetadataOrgFactory) {    
    var arrDepts = [];
    var objMapping = {};

    MetadataOrgFactory.getApiCall('getpublisheddepts', function (dataSuccess) {
        $scope.department = dataSuccess;
        for (var cntElem = 0; cntElem < dataSuccess.length; cntElem++) {
            
            var objDept = { id: dataSuccess[cntElem].DeptId, DeptId: dataSuccess[cntElem].DeptName }
            arrDepts.push(objDept);

            objMapping[dataSuccess[cntElem].DeptId] = dataSuccess[cntElem].DeptName;
            
        }      
        $scope.gridRole.columnDefs[1].editDropdownOptionsArray = arrDepts;
    }, function (dataError) {
    });
   

    $scope.gridRole = {
        data: 'roleData',
        columnDefs: [
          {
              field: 'RoleName', displayName: 'Role Name',              
          },
          {
              field: 'DeptId', displayName: 'Department Name',             
              editableCellTemplate: 'ui-grid/dropdownEditor',
              cellFilter: 'mapDepartmentName:this',
              editDropdownValueLabel: 'DeptId',
          },
          {
              field: 'RoleDesc', displayName: 'About Role',              
          },
          {
              field: 'WorkingHrs', displayName: 'Working Hours',              
          },
          {
              field: 'RequestNumber', displayName: 'RequestNumber',
              cellEditableCondition: true
          }
         
        ]

    }

    MetadataOrgFactory.getApiCall('getallroles', function (dataSuccess) {
        $scope.roleData = dataSuccess;
    }, function (dataError) {
    });

    
}])

.filter('mapDepartmentName', function () {
    return function (input, scope) {
        if (!input) {
            return '';
        } else {
            return objMapping[input];
        }
    };
});
<!DOCTYPE html>
<html>
<head>
    <title></title>	
    <style>
        .gridStyle {
            border: 5px solid #d4d4d4;
            height: 200px;
        }
    </style>
    <meta charset="utf-8" />
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.1.1/jquery.min.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.0/angular.min.js"></script>
    <link rel="stylesheet" href="https://cdn.rawgit.com/angular-ui/bower-ui-grid/master/ui-grid.min.css" />
    <script src="https://cdn.rawgit.com/angular-ui/bower-ui-grid/master/ui-grid.min.js"></script>
    <script src="../Scripts/AngularControllers/RoleController.js"></script>
    <script src="../Scripts/AngularServices/ApiCallService.js"></script>
</head>
<body ng-app="appHome">
    <div ng-controller="ctrlRole">
       
        <div class="gridStyle" ui-grid="gridRole" ui-grid-edit>
        </div>
    </div>

</body>
</html>

最佳答案

在工厂回调结束时调用 getpublisheddepts 中的 $scope.$apply()。

由于您没有展示您的工厂,我相信它会异步执行某些操作,而不会通知 View 以反射(reflect)更改。

关于javascript - CellFilter 在 UI-Grid 中的 $http 响应之前被调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43717706/

相关文章:

javascript - 你能在实例化后向 React JSX 元素添加一个键吗?

javascript - CSS 过渡回调

angularjs - ui.bootstrap.datepicker 清除按钮事件

angularjs - 如何将资源与两个不同的服务集成以使用它们提供的参数查询服务器?

javascript - AngularJS 服务/工厂从 $scope 变量动态 $compile HTML

angularjs - & 和 = 之间传递函数以隔离范围的区别

javascript - 使用 Greasemonkey 进行跨域发帖?

javascript - ASP.NET:表单提交时的 JS 回调返回要下载的文件

javascript - 获取数组中具有某些属性的项目数

ruby-on-rails - 如何跳过已经缩小的 Javascript 的预编译并仍然保留 Require 序列?