根据你的代码,您试图多次添加标准,那么你想用这些标准来筛选。
在你的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。
Plunkr链接:http://plnkr.co/edit/3yOmiIJ9Yu9RfAgmuVA7 –
如果您创建了正确的搜索模型,如search.name,那么您不需要在控件中使用“$ filter”请检查我的答案。 – Reza