萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> 使用AngularJS創建自定義的過濾器的方法

使用AngularJS創建自定義的過濾器的方法

   這篇文章主要介紹了使用AngularJS創建自定義的過濾器的方法,AngularJS是非常熱門的JavaScript庫,需要的朋友可以參考下

  Angularjs過濾器是 angularjs非常棒的特性之一。有朝一日,你可能需要使用自定義過濾器,幸運的是,你找到了這篇博文。

  下面顯示的是自定義過濾器長什麼樣子(請注意myfilter):

  我們的自定義過濾器叫做 "myfilter", 它有由 ':'隔開的4個參數.

  這是一個將會用到的樣本輸入:

  ?

1 2 3 4 5 6 $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"的項,這是樣本輸出:

  ?

1 2 3 4 5 6 Name Phone John 555-1276 Mike 555-4321 Adam 555-5678 David 555-8765 Mikay 555-5678

  過濾"555"的處理流程由 "windowScopedFilter"執行, 它是過濾器 'myfilter'的第四個參數.

  下面我們來實現這些功能 (把logging添加到每個輸入參數):

  ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 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了(譯者注:將信息顯示到控制台). 實際完成過濾的最重要的一部分是:

  ?

1 2 3 4 5 // filter if (5<=args.length) { return window[args[4]](input); } return input;

  "return window[args[4]](input)" 調用第四個參數, 它是 'windowScopedFilter'.

  這是控制台輸出:

  ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 "------------------------------------------------- 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

  完整代碼:

  ?

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 <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; }; });
copyright © 萬盛學電腦網 all rights reserved