我编写了一个过滤函数,它将根据您传递的参数返回数据。我希望在我的控制器中实现相同的功能。是否可以在控制器中重用过滤函数?
这是我迄今为止尝试过的:
function myCtrl($scope,filter1)
{
// i simply used the filter function name, it is not working.
}
我编写了一个过滤函数,它将根据您传递的参数返回数据。我希望在我的控制器中实现相同的功能。是否可以在控制器中重用过滤函数?
这是我迄今为止尝试过的:
function myCtrl($scope,filter1)
{
// i simply used the filter function name, it is not working.
}
将 $filter 注入到您的控制器中
function myCtrl($scope, $filter)
{
}
然后,无论在哪里想使用该过滤器,只需像这样使用它:$filter('filtername');
如果你想将参数传递给该过滤器,请使用单独的括号:
function myCtrl($scope, $filter)
{
$filter('filtername')(arg1,arg2);
}
其中arg1
是您要筛选的数组,而arg2
是用于筛选的对象。
var anyNumber = $filter('number')(12.222222, 2);
以获取12.22
。 - vinesh$filter("currency")(price, "$", 2)
因此,如果您拥有价格 = 200,该表达式将返回"$200.00"。 - Netsi1964$filter('filtter1')
(2个t),你不会注意到错误。然而,如果你注入filtter1Filter
,Angular会立即报错,提示依赖不存在。 - jkjustjoshing@Prashanth提供的答案是正确的,但是实现相同效果的更简单的方法。基本上,可以注入依赖关系:过滤器名称加上Filter
后缀,而不是注入$filter
依赖并使用调用它的奇怪语法($filter('filtername')(arg1,arg2);
)。
以问题中的示例为例,可以编写以下内容:
function myCtrl($scope, filter1Filter) {
filter1Filter(input, arg1);
}
需要注意的是,无论您使用什么命名约定,都必须将Filter
追加到过滤器名称:
要调用 fooFilter
,则引用 foo
要调用 fooFilterFilter
,则引用 fooFilter
var fooFilter = $filter('foo');
fooFilter(arg1, arg2);
解释:这段代码是在AngularJS框架中使用$filter服务来获取名为'foo'的过滤器函数,然后使用该函数传入arg1和arg2参数进行过滤。 - blindgaenger angular.module('FilterInControllerModule', []).
controller('FilterController', ['filterFilter', function(filterFilter) {
this.array = [
{name: 'Tobias'},
{name: 'Jeff'},
{name: 'Brian'},
{name: 'Igor'},
{name: 'James'},
{name: 'Brad'}
];
this.filteredArray = filterFilter(this.array, {name:'Igor'});
}]);
HTML
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Example - example-example96-production</title>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.3.0-beta.3/angular.min.js"></script>
<script src="script.js"></script>
</head>
<body ng-app="FilterInControllerModule">
<div ng-controller="FilterController as ctrl">
<div>
All entries:
<span ng-repeat="entry in ctrl.array">{{entry.name}} </span>
</div>
<div>
Filter By Name in angular controller
<span ng-repeat="entry in ctrl.filteredArray">{{entry.name}} </span>
</div>
</div>
</body>
</html>
以下是在 Angular 控制器中使用 filter
的另一个示例:
$scope.ListOfPeople = [
{ PersonID: 10, FirstName: "John", LastName: "Smith", Sex: "Male" },
{ PersonID: 11, FirstName: "James", LastName: "Last", Sex: "Male" },
{ PersonID: 12, FirstName: "Mary", LastName: "Heart", Sex: "Female" },
{ PersonID: 13, FirstName: "Sandra", LastName: "Goldsmith", Sex: "Female" },
{ PersonID: 14, FirstName: "Shaun", LastName: "Sheep", Sex: "Male" },
{ PersonID: 15, FirstName: "Nicola", LastName: "Smith", Sex: "Male" }
];
$scope.ListOfWomen = $scope.ListOfPeople.filter(function (person) {
return (person.Sex == "Female");
});
// This will display "There are 2 women in our list."
prompt("", "There are " + $scope.ListOfWomen.length + " women in our list.");
很简单,嘿?
假设你有以下简单的过滤器,它将一个字符串转换为大写,并带有一个参数仅针对第一个字符。
app.filter('uppercase', function() {
return function(string, firstCharOnly) {
return (!firstCharOnly)
? string.toUpperCase()
: string.charAt(0).toUpperCase() + string.slice(1);
}
});
直接通过$filter
进行筛选。app.controller('MyController', function($filter) {
// HELLO
var text = $filter('uppercase')('hello');
// Hello
var text = $filter('uppercase')('hello', true);
});
注意:这将使您可以访问所有过滤器。
将$filter
分配给一个变量
此选项允许您像使用函数
一样使用$filter
。
app.controller('MyController', function($filter) {
var uppercaseFilter = $filter('uppercase');
// HELLO
var text = uppercaseFilter('hello');
// Hello
var text = uppercaseFilter('hello', true);
});
仅加载特定的筛选器
您可以通过在筛选器名称后附加Filter
来仅加载特定的筛选器。
app.controller('MyController', function(uppercaseFilter) {
// HELLO
var text = uppercaseFilter('hello');
// Hello
var text = uppercaseFilter('hello', true);
});
你使用哪种选项是个人偏好,但我建议使用第三个,因为它是最易读的选项。
function ngController($scope,$filter){
$scope.name = "aaaa";
$scope.age = "32";
$scope.result = function(){
return $filter('lowercase')($scope.name);
};
}
控制器方法的第二个参数名称应为“$filter”,这样示例才能使用过滤功能。在此示例中,我使用了“lowercase”过滤器。我有另一个例子,是我为我的流程制作的:
我获得一个像这样带有值-描述的数组
states = [{
status: '1',
desc: '\u2713'
}, {
status: '2',
desc: '\u271B'
}]
在我的Filters.js文件中:
.filter('getState', function () {
return function (input, states) {
//console.log(states);
for (var i = 0; i < states.length; i++) {
//console.log(states[i]);
if (states[i].status == input) {
return states[i].desc;
}
}
return '\u2718';
};
})
然后,一个测试的变量(控制器):
function myCtrl($scope, $filter) {
// ....
var resp = $filter('getState')('1', states);
// ....
}
{{ variable | MyFilter: ... : ... }}
在控制器内部,您可以使用注入$filter服务
angular.module('MyModule').controller('MyCtrl',function($scope, $filter){
$filter('MyFilter')(arg1, arg2);
})
如果您需要更多示例,请点击以下链接
还有一种评估过滤器的方法,它与视图中的语法相似。调用可能会很复杂,但你可以构建一个快捷方式来简化操作。我喜欢字符串的语法与视图中完全一致。看起来是这样的:
function myCtrl($scope, $interpolate) {
$scope.$eval($interpolate( "{{ myvar * 10 | currency }} dollars." ))
}
似乎没有人提到过,你可以将一个函数作为arg2传入$filter('filtername')(arg1,arg2);
例如:
$scope.filteredItems = $filter('filter')(items, function(item){return item.Price>50;});