7

Używam interfejsu ui do wiązania danych z tabeli ról, która zawiera identyfikator działu jako klucz podstawowy. Dzwonię do Web Api, aby uzyskać wszystkie role w tabeli i pokazać w ui-grid.

Departament Tabela

enter image description here

Tabela Rola

enter image description here

Moim prawdziwym problemem jest to, że chcę przekonwertować identyfikator działu do Nazwa działu, gdy wiąże się z siecią za pomocą cellFilter i to jest dlaczego deklaruję objMapping do mapowania ID działu z nazwą działu. Ale za każdym razem, gdy uruchamiam, widzę, że funkcja niestandardowa cellFilter, tj. 'MapDepartmentName', jest wywoływana przed ustawieniem programu objMapping, a także nie jestem w stanie odwołać obiektu mapowania w 'mapDepartmentName'.

Moja sieć wygląda tak: -

enter image description here

Jednak kiedy edytować uzyskać wynik poniżej co jest absolutnie poprawne: -

enter image description here

Moje urywek kodu jak poniżej : -

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> \t 
 
    <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>

Odpowiedz

1

zakres połączeń $. $ Apply() w getpublisheddepts pod koniec fabryki zwrotnego.

jak ci się nie pokazała fabryka Wierzę, że robi to coś asynchronicznie, co nie informuje widoku o zmianach.

+0

To wywołanie asynchroniczne. $ scope. $ apply() też nie pomaga. – user1843970

1

Utknąłem w numerze przez długi czas. Dokonałem następującej zmiany kodu i otrzymuję również wyniki. Proszę dać mi znać, czy jest to poprawne rozwiązanie tego problemu: -

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.deptmapping = objDeptMapping;  //new code added here 
     $scope.gridRole.columnDefs[1].editDropdownOptionsArray = arrDepts; 
    }, function (dataError) { 
    }); 

Filtr klasy

.filter('mapDepartmentName', function() { 
    return function (input, scope) { 
     if (!input) { 
      return ''; 
     } else { 
      return scope.grid.appScope.deptmapping[input]; //Change in code 
     } 
    }; 
}); 
+0

to zasadniczo to, co powinieneś zrobić –