从数组中过滤掉空字符串后,有一些问题只显示第一个和最后一个重复的元素。
我的代码:
var myApp = angular.module('myApp', []);
myApp.controller("myCtrl", function ($scope, $window) {
$scope.items = [
{ name: "item1", color: "green", form: "" },
{ name: "item2", color: "", form: "circle" },
{ name: "item3", color: "red", form: "" },
{ name: "item4", color: "", form: "oval" },
{ name: "item5", color: "blue", form: "" },
{ name: "item6", color: "", form: "square" },
{ name: "item7", color: "yellow", form: "" },
{ name: "item8", color: "", form: "rectangle" }
];
});

<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<body ng-app="myApp" ng-controller="myCtrl" class="ng-scope">
<div ng-repeat="item in items" ng-if="item.form == ''">
{{item.name}}-{{item.color}}
</div>
<br />
<div ng-repeat="item in items" ng-if="item.color == ''">
{{item.name}}-{{item.form}}
</div>
<br />
</body>
&#13;
但是我只需要在列表中显示第一个和最后一个elenemt。 防爆。在第一个列表中:item1-green和item7-yellow(item3-red和item5-blue必须隐藏),second list item2-circle和item8-rectangle。
答案 0 :(得分:3)
If you only wanted to show first and last element of items inside ng-repeat
you could use $first
& $last
variable of ng-repeat
template which indicated $first
& $last
occurrence if they are true.
<div ng-repeat="item in items" ng-if="$first || $last">
{{item.name}}-{{item.form}}
</div>
Update
For such situation you should prefer to do custom filter, which will accept array
, propertyName
& valueToCheck
. At the end it will return 1st and last element
HTML
<div ng-repeat="item in items| returnFirstAndLastValue: 'form': ''">
{{item.name}}-{{item.color}}
</div>
<div ng-repeat="item in items| returnFirstAndLastValue: 'color': ''">
{{item.name}}-{{item.form}}
</div>
Filter
myApp.filter('returnFirstAndLastValue', function(){
return function(array, prop, valueToCheck){
var length = (array || []).length, tempOutput = [];
angular.forEach(array, function(ele, index){
if(ele[prop] === valueToCheck)
tempOutput.push(ele);
})
return tempOutput.filter(function(element, index){
if(index == 0 || index == (tempOutput.length - 1) )
return element;
})
}
})
答案 1 :(得分:1)
我为您的用例创建了自定义过滤器。 基本上,过滤器将通过过滤传递参数(形式和颜色)的空值来返回数组。
过滤后,您可以将$first
和$last
与ng-if
一起使用,以仅显示第一个和最后一个元素。
请参阅下面的代码。
var myApp = angular.module('myApp', []);
myApp.filter('customFilter', function() {
return function(input, param) {
if(input.length == 0) { return [];}
var result = [];
angular.forEach(input, function(item) {
if(item[param] && item[param]!= '') {
result.push(item);
}
});
return result;
}
})
myApp.controller("myCtrl", function ($scope, $window) {
$scope.items = [
{ name: "item1", color: "green", form: "" },
{ name: "item2", color: "", form: "circle" },
{ name: "item3", color: "red", form: "" },
{ name: "item4", color: "", form: "oval" },
{ name: "item5", color: "blue", form: "" },
{ name: "item6", color: "", form: "square" },
{ name: "item7", color: "yellow", form: "" },
{ name: "item8", color: "", form: "rectangle" }
];
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<body ng-app="myApp" ng-controller="myCtrl" class="ng-scope">
<div ng-repeat="item in items | customFilter:'color'" ng-if="$first || $last">
{{item.name}}-{{item.color}}
</div>
<br />
<div ng-repeat="item in items | customFilter:'form'" ng-if="$first || $last">
{{item.name}}-{{item.form}}
</div>
<br />
</body>
答案 2 :(得分:0)
我做到了;)
var myApp = angular.module('myApp', []);
myApp.controller("myCtrl", function ($scope, $window) {
$scope.items = [
{ name: "item1", color: "green", shape: "" },
{ name: "item2", color: "", shape: "circle" },
{ name: "item3", color: "red", shape: "" },
{ name: "item4", color: "", shape: "oval" },
{ name: "item5", color: "blue", shape: "" },
{ name: "item6", color: "", shape: "square" },
{ name: "item7", color: "yellow", form: "" },
{ name: "item8", color: "", shape: "rectangle" }
];
$scope.shape = function(item){
return !(item.color == '')
};
$scope.color = function(item){
return !(item.shape == '')
};
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<body ng-app="myApp" ng-controller="myCtrl" class="ng-scope">
<div ng-repeat="item in items | filter:shape" ng-if="$first || $last">
{{item.name}}-{{item.color}}
</div>
<br />
<div ng-repeat="item in items | filter:color" ng-if="$first || $last">
{{item.name}}-{{item.shape}}
</div>
<br />
</body>