根据您的代码,您尝试多次添加条件,然后您想使用这些条件进行过滤。
在您的 JSON 中,这里只有 3 个属性。{姓名、电话和年龄}。
因此,您的标准不应超过 3 行,并且不应有两次相同的内容。如果你这样做,你需要构建自己的过滤器。使用以下代码
$scope.newList = function() {
var searchBy = {};
angular.forEach($scope.newCriteria, function(criteria, key) {
searchBy[criteria.name] = criteria.value;
});
$scope.newfriends = $filter('filter')($scope.friends, searchBy);
}
和HTML如下
<div id="searchy">
<ul class="list-unstyled">
<li style="display: inline-block" ng-repeat="crtia in newCriteria">
<table>
<tr>
<td>
<select ng-model="crtia.name" ng-options="searchopt for searchopt in searchcriteria " ng-click="searchy.check()"></select>
</td>
<td>
<input ng-model="crtia.value" placeholder="{{crtia.name}}" ng-change="newList()" />
</td>
</tr>
</table>
</li>
</ul> <button ng-click="searchy.generate()">Add Criteria</button> </div>
这是更新的 plunker。
http://plnkr.co/edit/r5OcI366dyvLQ24fFIje?p=preview。