제 코드에 무슨 문제가 있는지 말해주세요. 표제 표제를 클릭하면 $ scope.sort가 올바른 값을 얻고 있지만 표가 사전 순으로 정렬되지 않습니다.AngularJs 정렬 순서가 제대로 작동하지 않습니다.
당신은 JSON 여기 파일 plunkr을 볼 수 있습니다 : 당신이 ngClick
를 DOM의 onclick
이벤트를 사용하지 때문에 콘솔 로그 http://embed.plnkr.co/DYwbqDzBVTkQalhDtc6i/
var ssgaApp = angular.module('ssgaApp', []);
\t ssgaApp.controller('mainCtrl',['$scope', '$http', function ($scope,$http) {
\t \t var getEntries = $http.get('altLoginServlet.json');
\t \t getEntries.success(function (data, status, headers, config) {
$scope.ajaxerror = false;
$scope.companies = data.data;
});
getEntries.error(function(data, status, headers, config) {
$scope.ajaxerror = true;
});
$scope.sort = {column: '', descending: true};
$scope.changeSort = function(column) {
// console.log($scope.sort);
$scope.sort.column = column;
$scope.sort.descending = !$scope.sort.descending;
console.log('$scope.sort.column', $scope.sort.column, '$scope.sort.descending', $scope.sort.descending);
$scope.currentPage = 1;
$scope.currentPage_grid = 1;
};
\t }])
\t .directive('changeSortdirective', ['$timeout', function($timeout) {
return {
restrict: 'A',
scope: {
changeSortAttr: '@changeSortdirective'
},
link: function (scope, element, attrs) {
console.log('changeSortAttr', scope.changeSortAttr);
element.on('click', function(){
console.log('changeSort bind', scope.changeSortAttr);
scope.$parent.changeSort(scope.changeSortAttr);
});
}
};
}]);
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
\t <div ng-app="ssgaApp" ng-controller="mainCtrl">
\t \t
\t \t <table class="leftPadding">
\t
\t <thead>
\t <tr>
\t <th width="80%">
<a href="javascript:void(0)" change-sortdirective="companyName">Name <span></span></a>
</th>
\t <th>
<a href="javascript:void(0)" change-sortdirective="id">ID <span></span></a>
</th>
\t </tr>
\t </thead>
\t
\t <tbody>
\t <tr ng-repeat="comp in companies | orderBy:sort.column:sort.descending ">
\t <td class="col1" ng-show="comp.companyName"><a href="javascript:void(0)" ng-click='toggleModal(comp.id)'>{{comp.companyName}}</a></td>
\t <td class="col1" ng-show="comp.loginName">
<a ng-click="doAltLogin(comp.loginName)" href="javascript:void(0)">{{comp.lastName}}, {{comp.firstName}}</a></td>
\t <td ng-bind="comp.id"></td>
\t </tr>
\t </tbody>
\t
\t </table>
\t </div>
덕분에) 나는'''angular.element.bind ('클릭'기능으로 행 전용 이제 이벤트들을 교체() {''' – STEEL