设为首页收藏本站

LUPA开源社区

 找回密码
 注册
文章 帖子 博客
LUPA开源社区 首页 业界资讯 技术文摘 查看内容

创建AngularJS自定义过滤器,带自定义参数

2014-7-24 11:03| 发布者: joejoe0332| 查看: 5463| 评论: 1|原作者: 徐继开|来自: oschina

摘要: Angularjs过滤器是 angularjs非常棒的特性之一。有朝一日,你可能需要使用自定义过滤器,幸运的是,你找到了这篇博文。下面显示的是自定义过滤器长什么样子(请注意myfilter):…… ...

  Angularjs过滤器是 angularjs非常棒的特性之一。有朝一日,你可能需要使用自定义过滤器,幸运的是,你找到了这篇博文。


  下面显示的是自定义过滤器长什么样子(请注意myfilter):


1
<tr ng-repeat="friend in friends |myfilter:'param1':'param2':true:'windowScopedFilter'">


  我们的自定义过滤器叫做 "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
 "------------------------------------------------- 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;  
   };  
 });  
 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>

酷毙

雷人

鲜花

鸡蛋

漂亮
  • 快毕业了,没工作经验,
    找份工作好难啊?
    赶紧去人才芯片公司磨练吧!!

最新评论

关于LUPA|人才芯片工程|人才招聘|LUPA认证|LUPA教育|LUPA开源社区 ( 浙B2-20090187 浙公网安备 33010602006705号   

返回顶部