使用AngularJS函数命令

时间:2014-07-10 14:49:55

标签: javascript angularjs angularjs-ng-repeat angularjs-orderby

我正在使用ng-repeat列出对象数组中的项目。我想使用orderBy(或者某些自定义排序过滤器)对这些项目进行排序。

但是,我想要排序的字段不是保存在对象本身的数组中,而是我有一个函数,我可以用它为每个单独的对象计算它;但它需要将每个单独的对象传递给它。

这样的事情:

<table>
    <tr ng-repeat="item in sortedItems = (items | orderBy:'getStatus(item)':reverse)">
        <td>Title: {{item.title}}</td>
        <td>Status: {{getStatus(item)}}</td>
    </tr>
</table>

其中getStatus在控制器内部为:

$scope.getStatus = function(item){
    var days = item.days
    if(days<=100){
        var x=100-item.days+" ";
        if(days===99){
            return x+"day left";
        }
        return x+"days left";
    }
    return "Completed";
};

所以它返回一个字符串。

有什么方法可以按需要对数组中每个单独项目的函数进行排序,以便对方式进行排序?

1 个答案:

答案 0 :(得分:3)

当然,只需从orderBy子句中删除参数,它就需要单个项目:

<tr ng-repeat="item in sortedItems = (items | orderBy: getStatus :reverse)">