AngularJS orderBy 使用要點

AngularJS orderBy 使用要點總結:數組

  1,書寫格式函數

基本應用格式爲:spa

ng-repeat="item in itemList | orderBy:p1:p2"

參數p1能夠是字段名或自定義函數,p2指是否逆序,默認是falsecode

舉例:排序

假設$scope中有ci

$scope.itemList=[{id:201,name:'abc',amount:100},{id:100,name:'zdb',amount:100},
{id:10,name:'xxx',amount:200},{id:80,name:'231',amount:1020},
{id:50,name:'ppp',amount:20},{id:1,name:'hhh',amount:1100}];

按照id,倒排序it

1io

ng-repeat="item in itemList | orderBy:'id':true"table

    2,自定義排序:function

controller中設置自定義函數,函數接受參數爲當前的item,須要返回一個數值表明該item的順序

$scope.orderIt=function(item){
    if(item.name.indexOf('h')===0)return 0;
    return 1;
};

使用方法:

ng-repeat="item in itemList | orderBy:orderIt"

  3,多字段排序:

若是單個字段排序不能知足需求,那就要祭出絕活了!orderBy還支持多字段排序,方法以下

ng-repeat="item in itemList | orderBy:[orderIt,'name','-amount']

沒錯,第一個參數傳遞數組,能夠是自定義函數或字段名,字段名前面加「-」,表明倒排序。

相關文章
相關標籤/搜索