定义的参数进行搜索所以我有一个搜索框,其中有一些参数,我想限制搜索范围。这包括我的例子中的名字和姓氏。Angular JS:使用参数
所以我一直在努力实现这个像这样。这是下拉列表的代码。
<select id="usersearchby" ng-model="searchFilter" ng-change="selectAction()">
<option>Search By ...</option>
<option value="lastName">Last Name</option>
<option value="firstName">First Name</option>
</select>
这是输入搜索字段的代码。
<input type="search" ng-if="searchFilter != 'firstName' && searchFilter != 'lastName'" ng-model="searchText">
<input type="search" ng-if="searchFilter == 'firstName'" ngModel="searchText.first_name">
<input type="search" ng-if="searchFilter == 'lastName'" ngModel="searchText.last_name">
这是显示结果的div的代码。
<div class="block_line_item userlist_expanded" ng-repeat="user in users | filter: searchText">
此代码不工作,但是,如果我只是有说FIRST_NAME(没有条件输入)单个输入搜索框,它工作得很好!我究竟做错了什么?有没有更好的方法来做到这一点?
JSON数据我工作的一个示例:
[{"role":"1","credentials":"","work_phone":"206–298–3059","last_name":"Doe","middle_name":"","suffix":"","title":"Mr.","mobile_phone":"1–877–932–4259","id":1,"fax":"135–678-6357","first_name":"John","email":"[email protected]","username":"user1"}, {"role":"1","credentials":"","work_phone":"206–298–3059","last_name":"Doe","middle_name":"","suffix":"","title":"Mr.","mobile_phone":"1–877–932–4259","id":2,"fax":"135–678–6357","first_name":"Jane","email":"[email protected]","username":"user2"}]
能否请您提供您的控制器代码? – 2014-12-08 06:46:09
非常基本的:'$ http.get(“/ users”)。success(function(data){ $ scope.users = data; });'用户数据在json中,包含first_name和last_name的键值对等等。 – geekchic 2014-12-08 06:48:30
它看起来像过滤器有问题:searchText,因为现在值在searchText.first_name或searchText.last_name – 2014-12-08 06:51:02