[英]AngularJS filter is not working in object
我的AngularJS過濾器不適用於對象。
視圖:
<input type="text" ng-model="searchKeyUser.$" placeholder="Pesquisar Chaves" class="form-control"><br>
<ul class="list-group">
<li class="list-group-item clicavel chaves" ng-repeat="chave in keyUsers | filter:searchKeyUser" ng-class="{ active:Grupo.isActiveKey(chave.Chave.id)}" ng-click="Grupo.mostrar()">
{{chave.Chave.chave}}{{chave.show}}
</li>
</ul>
我嘗試使用searchKeyUser。$,searchKeyUser.Chave。$,searchKeyUser.Chave.chave,但沒有任何反應。 詳細信息:文本{{chave.Chave.chave}}{{chave.show}}
正在運行。
編輯:Js代碼:
(function() {
var app = angular.module('groupUsers', []);
app.controller('GroupsController', function($scope, $http){
//Busca rel Chaves Usuarios
$http.get(myBaseUrl + '/QlikRelKeyUser/retornoGroups').success(function(data, status, headers, config) {
$scope.keyUsers = data;
console.log($scope.keyUsers);
for(x in $scope.keyUsers){
aux = 0;
qtd = $scope.keyUsers[x].QlikUser.length;
for(y in $scope.keyUsers[x].QlikUser){
aux++;
if(qtd == 1){
$scope.keyUsers[x].show = ' (' + $scope.keyUsers[x].QlikUser[y].nome + ')';
}else if(aux == qtd){
$scope.keyUsers[x].show += ', ' + $scope.keyUsers[x].QlikUser[y].nome + ')';
}else{
if(aux==1){
$scope.keyUsers[x].show = ' (' + $scope.keyUsers[x].QlikUser[y].nome;
}else{
$scope.keyUsers[x].show += ', ' + $scope.keyUsers[x].QlikUser[y].nome;
}
}
}
}
console.log('');
}).error(function(data, status, headers, config) {
console.log('NÃO FUNFOU');
console.log(config);
});
$scope.searchKeyUser = {$:''};
});
編輯2:相同的視圖:
<input type="text" ng-model="searchGroup.$" placeholder="Pesquisar Grupos" class="form-control"><br>
<ul class="list-group" >
<li class="list-group-item clicavel" ng-repeat="group in grupos | filter:searchGroup" ng-class="{ active:Grupo.isSet(group.QlikUserGroup.id)}" ng-click="Grupo.setActive(group.QlikUserGroup.id)">
{{group.QlikUserGroup.nome}}
<span class='badge bg-important'>1</span>
<span class='badge' stylee='padding-right:30px;'>{{Grupo.totalKeys(group.QlikUserGroup.id)}}</span>
</li>
</ul>
相同的JS:
$http.get(myBaseUrl + '/QlikUserGroup/retornoGroups').success(function(data, status, headers, config) {
$scope.grupos = data;
}).error(function(data, status, headers, config) {
console.log('NÃO FUNFOU');
console.log(config);
});
我的console.log($scope.grupos);
返回:
Array[67]
0: Object
$$hashKey: "object:530"
QlikUserGroup: Object
id: "1"
nome: "Name name name"
__proto__: Object
__proto__: Object
1: Object
2: Object
3: Object
4: Object
...
角度過濾器僅適用於數組,但您嘗試傳遞object 。 所以你至少有兩個解決方案
在js中從對象創建數組,像這樣
$scope.keyUsers = []; console.log(data); for(x in data){ var el = data[x]; $scope.keyUsers.push(el); el.show = '('+ el.QlikUser.map(function(el){ return el.nome; }).join(', ') +')'; } console.log($scope.keyUsers);
var data = { '1': { 'QlikUser': [{ nome: 'a' }, { nome: 'b' }, { nome: 'c' }, { nome: 'd' }, ] } } var keyUsers = []; console.log(data); for (x in data) { var el = data[x]; keyUsers.push(el); el.show = '(' + el.QlikUser.map(function(el) { return el.nome; }).join(', ') + ')'; } console.log(keyUsers);
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.