2

我想传递变量 $index 像过滤器的参数。代码如下:

HTML:

<div ng-app='myApp' ng-controller="Main" >
    <div ng-repeat="i in (filtered = (elements | myFilter: $index))" >

        <ul>
            <il ng-repeat="i in filtered">{{i.T}}</il>
        </ul>


    </div>
</div>

JS:

var myApp = angular.module('myApp', [])
.filter("myFilter", function(){
    return function(input, index){
        var newArray = [];
        for(var x = 0; x < input.length; x+=2){
             newArray.push(input[index]);   
        }
        return newArray;
    }
});


function Main($scope){
    $scope.elements = [
        { T: 't1', V: "v1"},
        { T: 't2', V: "v2"},
        { T: 't3', V: "v3"},
        { T: 't4', V: "v4"},
        { T: 't5', V: "v5"}
    ];
} 

我已经证明,如果我传递了一个类似参数的数字,它就可以工作。但是当我传递变量 $index 时,代码不起作用。

有没有像过滤器中的参数一样传递变量 $index 或 ng-repeat 的索引?

问候。

编辑:

真的,我想展示这样的东西:

... t1t2 t3t4 t5 ... 或在 HTML 中:

...

<div>
    <ul>
       <il>t1</il>
       <il>t2</il>
    </ul>
</div>
<div>
    <ul>
       <il>t3</il>
       <il>t4</il>
    </ul>
</div>
<div>
    <ul>
       <il>t5</il>
    </ul>
</div>
4

1 回答 1

0

我看不到$index在过滤器中使用的原因,因为过滤器运行在所有列表中。

但是我会在没有过滤器的情况下实现相同的逻辑,例如:

<div ng-controller = "fessCntrl"> 
<div ng-repeat="i in elements" >
        <ul>
            <il ng-show="$index % 2 == 0">{{i.T}}</il>
        </ul>
    </div>
</div> 

演示Fiddle

使用过滤器,您可以编写如下内容:

HTML

<div ng-controller = "fessCntrl"> 
<div ng-repeat="i in elements | myFilter" >
        <ul>
            <il>{{i.T}}</il>
        </ul>
    </div>
</div>

JS

.filter("myFilter", function(){
    return function(input){
        console.log(input);

        var newArray = [];
        for(var x = 0; x < input.length; x+=2){
             newArray.push(input[x]);   
        }
        return newArray;
    }
});

演示 2Fiddle

于 2013-11-05T23:41:08.630 回答