Aqui está o código que não está funcionando: Demo: http://jsfiddle.net/8dt94/63/
<div ng-controller="MyCtrl">
<input type="text" ng-model="searchText" />
<ul ng-repeat="strVal in arrVal|orderBy|filter:searchText" >
<li>{{strVal}}</li>
</ul>
</div>
var app=angular.module('myApp', []);
app.controller('MyCtrl', function ($scope,$filter) {
$scope.arrVal = ['one','two','three','four','five','six'];
});
Respostas:
Você pode pedir por um método, então você pode usar o método toString
<ul ng-repeat="strVal in arrVal | orderBy:'toString()' | filter:searchText">
fonte
[2,5,3,1,6, 33]
forma, então em vez ftoString()
useivalueOf()
e funcionou perfeitamente. Obrigado pela solução.Escreva um filtro personalizado :
app.filter('mySort', function() { return function(input) { return input.sort(); } });
HTML:
<ul ng-repeat="strVal in arrVal|filter:searchText|mySort">
Fiddle .
fonte