Angularjs过滤器是 angularjs非常棒的特性之一。有朝一日,你可能需要使用自定义过滤器,幸运的是,你找到了这篇博文。
下面显示的是自定义过滤器长什么样子(请注意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\'的第四个参数.
下面我们来实现这些功能 (把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\'.
这是控制台输出:
\"------------------------------------------------- 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
完整代码:
<html> <head> <script src=\"angular.min.js\"></script> <script type=\"text/javascript\"> 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\'}]; }]); </script> </head> <body ng-app=\"MyFilterApp\"> <div ng-controller=\"MyFilterController\"> <table id=\"searchTextResults\"> <tr><th>Name</th><th>Phone</th></tr> <tr ng-repeat=\"friend in friends |myfilter:\'param1\':\'param2\':true:\'windowScopedFilter\'\"> <td>{{friend.name}}</td> <td>{{friend.phone}}</td> </tr> </table> </div> <hr> </body> </html>
本文地址:https://www.stayed.cn/item/10711
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我