使用AngularJS创建自定义的过滤器的方法


Posted in Javascript onJune 18, 2015

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>
Javascript 相关文章推荐
filters.revealTrans.Transition使用方法小结
Aug 19 Javascript
chrome下jq width()方法取值为0的解决方法
May 26 Javascript
jQuery实现根据类型自动显示和隐藏表单
Mar 18 Javascript
JS模仿编辑器实时改变文本框宽度和高度大小的方法
Aug 17 Javascript
jQuery鼠标移动图片上实现放大效果
Jun 25 jQuery
Angular 容器部署的方法
Apr 17 Javascript
element el-input directive数字进行控制
Oct 11 Javascript
Vue中computed、methods与watch的区别总结
Apr 10 Javascript
微信小程序绑定手机号获取验证码功能
Oct 22 Javascript
jquery插件懒加载的示例
Oct 24 jQuery
解决pycharm双击但是无法打开的情况
Oct 31 Javascript
8个JS的reduce使用实例和reduce操作方式
Oct 05 Javascript
深入讲解AngularJS中的自定义指令的使用
Jun 18 #Javascript
3个可以改善用户体验的AngularJS指令介绍
Jun 18 #Javascript
在AngularJS应用中实现一些动画效果的代码
Jun 18 #Javascript
使用AngularJS对路由进行安全性处理的方法
Jun 18 #Javascript
浅谈Node.js中的定时器
Jun 18 #Javascript
浅析AngularJS中的生命周期和延迟处理
Jun 18 #Javascript
Node.js事件驱动
Jun 18 #Javascript
You might like
PHP获取类中常量,属性,及方法列表的方法
2009/04/09 PHP
php 验证码实例代码
2010/06/01 PHP
图解找出PHP配置文件php.ini的路径的方法
2014/08/20 PHP
php自定义扩展名获取函数示例
2016/12/12 PHP
PHP程序员简单的开展服务治理架构操作详解(三)
2020/05/14 PHP
JavaScript Event学习第四章 传统的事件注册模型
2010/02/07 Javascript
jquery星级插件、支持页面中多次使用
2012/03/25 Javascript
JS中 用户登录系统的解决办法
2013/04/15 Javascript
jquery数据验证插件(自制,简单,练手)实例代码
2013/10/24 Javascript
Angularjs整合微信UI(weui)
2016/03/15 Javascript
谈一谈js中的执行环境及作用域
2016/03/30 Javascript
canvas实现手机端用来上传用户头像的代码
2016/10/20 Javascript
Vue修改mint-ui默认样式的方法
2018/02/03 Javascript
vue利用axios来完成数据的交互
2018/03/23 Javascript
用WebStorm进行Angularjs 2开发(环境篇:Windows 10,Angular-cli方式)
2018/12/05 Javascript
使用post方法实现json往返传输数据的方法
2019/03/30 Javascript
使用jQuery mobile NuGet让你的网站在移动设备上同样精彩
2019/06/18 jQuery
Vue中父子组件的值传递与方法传递
2020/09/28 Javascript
[05:28]刀塔密之一:团结则存
2014/07/03 DOTA
Python处理RSS、ATOM模块FEEDPARSER介绍
2015/02/18 Python
python中sys.argv参数用法实例分析
2015/05/20 Python
Python中动态创建类实例的方法
2017/03/24 Python
Python 多核并行计算的示例代码
2017/11/07 Python
pandas表连接 索引上的合并方法
2018/06/08 Python
使用python 打开文件并做匹配处理的实例
2019/01/02 Python
python 内置函数汇总详解
2019/09/16 Python
Python要求O(n)复杂度求无序列表中第K的大元素实例
2020/04/02 Python
六种酷炫Python运行进度条效果的实现代码
2020/07/17 Python
西班牙灯具网上商店:Lampara.es
2018/06/05 全球购物
正风肃纪查摆剖析材料
2014/10/10 职场文书
2014年社区妇联工作总结
2014/12/02 职场文书
涨价通知
2015/04/23 职场文书
党支部季度考核意见
2015/06/02 职场文书
2015教师个人师德工作总结
2015/10/23 职场文书
python神经网络ResNet50模型
2022/05/06 Python
WinServer2012搭建DNS服务器的方法步骤
2022/06/10 Servers