AngularJSを使用してカスタムフィルタを作成する方法
5768 ワード
Angularjsフィルタはangularjsの素晴らしい特性の一つである.ある日、カスタムフィルタを使う必要があるかもしれませんが、幸いなことに、このブログを見つけました.
次に、カスタムフィルタの長さを示します(myfilterに注意してください):
カスタムフィルタは「myfilter」と呼ばれ、':'で区切られた4つのパラメータがあります.
使用するサンプル入力です.
フィルタは、電話番号に「555」が含まれている項目のみを表示します.これはサンプル出力です.
「555」をフィルタ処理するプロセスは「windowScopedFilter」によって実行され、フィルタ「myfilter」の4番目のパラメータである.
次に、これらの機能を実装します(loggingを各入力パラメータに追加します):
上のコードの多くはlogです(訳者注:コンソールに情報を表示します).実際にフィルタリングを完了する最も重要な部分は、次のとおりです.
「return window[args[4]」(input)は、「windowScopedFilter」という4番目のパラメータを呼び出します.
これはコンソール出力です.
完全なコード:
次に、カスタムフィルタの長さを示します(myfilterに注意してください):
カスタムフィルタは「myfilter」と呼ばれ、':'で区切られた4つのパラメータがあります.
使用するサンプル入力です.
$scope.friends = [{name:'John', phone:'555-1276'},
{name:'Annie', phone:'800-BIG-MARY'},
{name:'Mike', phone:'555-4321'},
{name:'Adam', phone:'555-5678'},
{name:'David', phone:'555-8765'},
{name:'Mikay', phone:'555-5678'}];
フィルタは、電話番号に「555」が含まれている項目のみを表示します.これはサンプル出力です.
Name Phone
John 555-1276
Mike 555-4321
Adam 555-5678
David 555-8765
Mikay 555-5678
「555」をフィルタ処理するプロセスは「windowScopedFilter」によって実行され、フィルタ「myfilter」の4番目のパラメータである.
次に、これらの機能を実装します(loggingを各入力パラメータに追加します):
var myapp = angular.module('MyFilterApp', []);
myapp.filter('myfilter', function() {
return function(input, param1) {
console.log("------------------------------------------------- begin dump of custom parameters");
console.log("input=",input);
console.log("param1(string)=", param1);
var args = Array.prototype.slice.call(arguments);
console.log("arguments=", args.length);
if (3<=args.length) {
console.log("param2(string)=", args[2]);
}
if (4<=args.length) {
console.log("param3(bool)=", args[3]);
}
console.log("------------------------------------------------- end dump of custom parameters");
// filter
if (5<=args.length) {
return window[args[4]](input);
}
return input;
};
});
上のコードの多くはlogです(訳者注:コンソールに情報を表示します).実際にフィルタリングを完了する最も重要な部分は、次のとおりです.
// filter
if (5<=args.length) {
return window[args[4]](input);
}
return input;
「return window[args[4]」(input)は、「windowScopedFilter」という4番目のパラメータを呼び出します.
これはコンソール出力です.
"------------------------------------------------- begin dump of custom parameters" custom_filter_function.html:21
"input=" [object Array] custom_filter_function.html:22
"param1(string)=" "param1" custom_filter_function.html:23
"arguments=" 5 custom_filter_function.html:25
"param2(string)=" "param2" custom_filter_function.html:27
"param3(bool)=" true custom_filter_function.html:30
"------------------------------------------------- end dump of custom parameters" custom_filter_function.html:32
"------------------------------------------------- begin dump of custom parameters" custom_filter_function.html:21
"input=" [object Array] custom_filter_function.html:22
"param1(string)=" "param1" custom_filter_function.html:23
"arguments=" 5 custom_filter_function.html:25
"param2(string)=" "param2" custom_filter_function.html:27
"param3(bool)=" true custom_filter_function.html:30
"------------------------------------------------- end dump of custom parameters" custom_filter_function.html:32
完全なコード:
function windowScopedFilter (input) {
var output = [];
angular.forEach(input, function(v,k){
if (v.phone.contains("555")) {
output.push(v);
}
});
return output;
}
var myapp = angular.module('MyFilterApp', []);
myapp.filter('myfilter', function() {
return function(input, param1) {
console.log("------------------------------------------------- begin dump of custom parameters");
console.log("input=",input);
console.log("param1(string)=", param1);
var args = Array.prototype.slice.call(arguments);
console.log("arguments=", args.length);
if (3<=args.length) {
console.log("param2(string)=", args[2]);
}
if (4<=args.length) {
console.log("param3(bool)=", args[3]);
}
console.log("------------------------------------------------- end dump of custom parameters");
// filter
if (5<=args.length) {
return window[args[4]](input);
}
return input;
};
});
myapp.controller('MyFilterController', ['$scope', function($scope) {
$scope.friends = [{name:'John', phone:'555-1276'},
{name:'Annie', phone:'800-BIG-MARY'},
{name:'Mike', phone:'555-4321'},
{name:'Adam', phone:'555-5678'},
{name:'David', phone:'555-8765'},
{name:'Mikay', phone:'555-5678'}];
}]);
Name Phone
{{friend.name}}
{{friend.phone}}