【发布时间】:2014-04-28 08:13:53
【问题描述】:
您好,
我是 Angular 新手。
在我当前的演示应用程序中,我使用选择过滤器 ng-option 创建了一些用户列表。
有一些我没有找到的错误。
错误:
当我选择女性时,它会过滤并只显示女性用户
但是当我选择
男性选项它向我显示完整列表并且不过滤女性用户。
这是我的代码:
html页面:
<div class="row" style="margin-top: 15px;">
<div class="col-lg-2 divPad">
<!--Sidebar content-->
<b>Sort by gender:</b>
<select ng-model="query.gender" class="btn btn-default" >
<option value="">All users</option>
<option ng-repeat="gender in genders" value="{{gender}}">{{gender}}</option>
</select>
</div>
</div>
<div class="row" style="margin-top: 15px;">
<div class="col-lg-2 divPad">
<b>Sort by Hobbies:</b>
<input class="form-control" ng-model="query.hobby" >
</div>
</div>
<div class="row" style="margin-top: 15px;">
<div class="col-lg-12">
<ul class="phones">
<li ng-repeat="user in users | filter:query " class="thumbnail phone-listing">
<a href="#/users/{{user.name}}" class="thumb">
<img style="margin-top: 15px;" ng-src="{{user.imageUrl}}"></a>
<a href="#/users/{{user.name}}">{{user.name}}</a>
<p><b>Hobby:</b> {{user.hobby}}</p>
<p><b>Gender:</b> {{user.gender}}</p>
</li>
</ul>
</div>
</div>
控制器页面:
zenvaControllers.controller('UserListCtrl', ['$scope', 'User', function ($scope, User) {
$scope.users = User.query();
$scope.genders = ["Male", "Female"];
}]);
json 页面:
[
{
"name": "Lucy",
"gender": "Female",
"hobby": "pets",
"imageUrl": "img/users/avatar1.png"
},
{
"name": "Betty",
"gender": "Female",
"hobby": "pets",
"imageUrl": "img/users/avatar2.png"
},
{
"name": "Ronald",
"gender": "Male",
"hobby": "music",
"imageUrl": "img/users/avatar3.png"
},
{
"name": "Christopher",
"gender": "Male",
"hobby": "sports",
"imageUrl": "img/users/avatar4.png"
},
{
"name": "Ximena",
"gender": "Female",
"hobby": "reading",
"imageUrl": "img/users/avatar5.png"
},
{
"name": "Paul",
"gender": "Male",
"hobby": "shopping",
"imageUrl": "img/users/avatar6.png"
},
{
"name": "Charlie",
"gender": "Male",
"hobby": "pets",
"imageUrl": "img/users/avatar7.png"
}
]
提前致谢。
【问题讨论】:
-
欢迎来到 StackOverflow。使用自定义过滤器,请参见此处的示例:plnkr.co/edit/3nZYxDOLnsV1Zk7YS5Mm?p=preview
-
感谢它使用复选框解决方案,但我的下拉过滤器仍然有什么问题?
标签: javascript angularjs ng-options