AngularJs 排序 orderBy 无法正常工作

标签 angularjs sorting angularjs-orderby

请告诉我我的代码有什么问题。当您单击表标题时, $scope.sort 会获取正确的值,但它不会按字母顺序对表进行排序。

您可以在此处使用 JSON 文件查看 plunkr:http://plnkr.co/edit/DYwbqDzBVTkQalhDtc6i?p=preview

在此处查看控制台日志 http://embed.plnkr.co/DYwbqDzBVTkQalhDtc6i/

var ssgaApp = angular.module('ssgaApp', []);

	ssgaApp.controller('mainCtrl',['$scope', '$http', function ($scope,$http) {
		var getEntries = $http.get('altLoginServlet.json');

		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;
        };

	}])
	.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>



	<div ng-app="ssgaApp" ng-controller="mainCtrl">
		

		<table class="leftPadding">
  	        
  	        <thead>
  	            <tr>
  	                <th width="80%">
                    <a href="javascript:void(0)" change-sortdirective="companyName">Name <span></span></a>
                    </th>
  	                <th>
                    <a href="javascript:void(0)" change-sortdirective="id">ID <span></span></a>
                    </th>
  	            </tr>
  	        </thead>
  	        
  	        <tbody>
  	            <tr ng-repeat="comp in companies | orderBy:sort.column:sort.descending ">
  	                <td class="col1" ng-show="comp.companyName"><a href="javascript:void(0)" ng-click='toggleModal(comp.id)'>{{comp.companyName}}</a></td>
  	                <td class="col1" ng-show="comp.loginName">
                    <a ng-click="doAltLogin(comp.loginName)" href="javascript:void(0)">{{comp.lastName}}, {{comp.firstName}}</a></td>
  	                <td ng-bind="comp.id"></td>
  	            </tr>
  	        </tbody>
  	        
  	    </table>


	</div>

最佳答案

由于您使用 DOM 的 onclick 事件而不是 ngClick 指令,因此 Angular 不会检测用户的交互。

您可能需要手动刷新$scope:

      element.on('click', function() {
        scope.$apply(function() {
          scope.$parent.changeSort(scope.changeSortAttr);
        });
      });

关于AngularJs 排序 orderBy 无法正常工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27919926/

相关文章:

javascript - Angular 带数据触发器 ='focus' 不工作

javascript - JS 按特定字符串属性对对象数组进行排序(不是升序或降序)

javascript - ng-repeat order通过保持固定的最高值

javascript - Angular JS : Increment a Counter in a Service From Controller

javascript - ng-class 中的字符串前缀

ruby - 使用多个标准对二维数组进行排序

html - Angular 2将新项目添加到列表时,自定义管道不重新排序列表

angular5 - 角度 5 ,按升序/降序排序

javascript - 一个元素上的多个指令不起作用

java - 为什么测试顺序会改变测试结果?