AngularJS过滤器filter用法分析


Posted in Javascript onDecember 11, 2016

本文实例讲述了AngularJS过滤器filter用法。分享给大家供大家参考,具体如下:

在开发中,经常会遇到这样的场景

如用户的性别分为“男”和“女”,在数据库中保存的值为1和0,用户在查看自己的性别时后端返回的值自然是1或0,前端要转换为“男”或“女”再显示出来;

如我要换个羽毛球拍,某猫上羽毛球拍的品牌多达数十种,我想单独查看YONEX这个品牌的羽毛球拍;

买完羽毛球拍我还想买一桶羽毛球,点击按销量排序展示商品;

AngularJS过滤器filter用法分析

以上三种场景分别对数据进行了转换/筛选/排序,总而言之就是对数据的格式化,AngularJS的filter就是用来做这个事的。

内置过滤器

AngularJS内置了很多过滤器,在HTML模板的绑定符号{{}}内通过|来调用过滤器

如字母转换成大写:

$scope.name='wangmeijian'

{{name | uppercase}}  // 输出 WANGMEIJIAN

数字转成千分位写法:

$scope.num = 12345678

{{num | number}} // 输出 12,345,678

日期格式化:

$scope.date=new Date()

{{date | date:'yy-MM-dd'}}  // 输出 2015-11-19

数字格式化成货币:

$scope.num=987654321

{{num | currency:'¥'}}  // 输出 ¥987,654,321.00

demo示例:http://runjs.cn/code/ztgq7fwg

稍微复杂一点的过滤器——‘filter',可以返回给定数组的子集,它接收一个参数,这个参数可以是字符串、对象、函数

字符串:返回所有包含这个字符串的元素,想要返回不包含这个字符串的元素则在前面加!

demo:

{{['wang','mei','jian'] | filter:'a'}} // 返回包含字母a的元素 ['wang','jian']

对象:Angular会将待过滤对象的属性与这个对象中的同名属性进行比较,如果属性值是字符串会判断是否包含该字符串(注意这里是包含,并不需要完全相等)

demo:

{{ [
  {
    name: 'wangmeijian',
    sex: 'boy'
  },
  {
    name: 'bokeyuan',
    sex: 'sex'
  }
  ] | filter:{
    sex: 'bo'

}
}}
// 输出 [{"name":"wangmeijian","sex":"boy"}]

函数:对每个元素都执行该函数,返回非假值的元素会出现在新的数组中并返回

demo:

$scope.getNumber = function(n){
return !isNaN(n);
}
{{ ['demo',2,3] | filter:getNumber}} // 输出 [2,3]

自定义过滤器

当内置函数不能满足你的业务需求时,就需要自定义一个过滤器,自定义过滤器返回一个函数,函数的参数就是HTML模板中|左侧的数据,它会自动传入过滤器中

比如需求是将一句话中的每个单词首字母变成大写

<html ng-app='app'>
  <head>
    <title>AngularJS过滤器filter入门</title>
    <script type="text/javascript" src="http://cdn.bootcss.com/angular.js/1.5.0-beta.1/angular.js"></script>
  </head>
  <body ng-controller='myController'>
    <p>{{ str | capitalize}}</p>
    <!-- 输出 Hello, Welcome To Bokeyuan! -->
    <script type="text/javascript">
    var app = angular.module('app',[])
    .controller('myController',['$scope', function($scope){
      $scope.str = 'hello, welcome to bokeyuan!'
    }])
    .filter('capitalize', function(){
      return function(str){
        var arr = str.split(/\s+/);
        for (var i = 0; i < arr.length; i++) {
          arr[i] = arr[i].substr(0,1).toUpperCase() + arr[i].slice(1);
        };
        return arr.join(" ")
      }
    })
    </script>
  </body>
</html>

需要注意的是,内置过滤器‘filter'的参数是函数时,会对数组的每个元素执行该函数,自定义过滤器是对数组对象执行它return的函数

希望本文所述对大家AngularJS程序设计有所帮助。

Javascript 相关文章推荐
解析jquery获取父窗口的元素
Jun 26 Javascript
jquery阻止冒泡事件使用模拟事件
Sep 06 Javascript
JS将表单导出成EXCEL的实例代码
Nov 11 Javascript
JQuery Tips相关(1)----关于$.Ready()
Aug 14 Javascript
js+HTML5实现canvas多种颜色渐变效果的方法
Jun 05 Javascript
基于jquery实现人物头像跟随鼠标转动
Aug 23 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
Sep 25 Javascript
JS Ajax请求如何防止重复提交
Jun 13 Javascript
原生JS实现移动端web轮播图详解(结合Tween算法造轮子)
Sep 10 Javascript
原生JS实现小小的音乐播放器
Oct 16 Javascript
搭建Vue从Vue-cli到router路由护卫的实现
Nov 14 Javascript
JS Ajax请求会话过期处理问题解决方法分析
Nov 16 Javascript
jquery判断页面网址是否有效的两种方法
Dec 11 #Javascript
JavaScript奇技淫巧44招【实用】
Dec 11 #Javascript
利用JS判断鼠标移入元素的方向
Dec 11 #Javascript
实现JavaScript高性能的数据存储
Dec 11 #Javascript
探索Javascript中this的奥秘
Dec 11 #Javascript
实例浅析js的this
Dec 11 #Javascript
解析js如何获取css样式
Dec 11 #Javascript
You might like
使用PHP Socket写的POP3类
2013/10/30 PHP
php文件缓存类汇总
2014/11/21 PHP
Yii入门教程之Yii安装及hello world
2014/11/25 PHP
PHP编程中尝试程序并发的几种方式总结
2016/03/21 PHP
PHP给前端返回一个JSON对象的实例讲解
2018/05/31 PHP
PHP配合fiddler抓包抓取微信指数小程序数据的实现方法分析
2020/01/02 PHP
prototype 源码中文说明之 prototype.js
2006/09/22 Javascript
asp 的 分词实现代码
2007/05/24 Javascript
Microsfot .NET Framework4.0框架 安装失败的解决方法
2013/08/14 Javascript
IE6 hack for js 集锦
2014/09/23 Javascript
纯JavaScript实现的兼容各浏览器的添加和移除事件封装
2015/03/28 Javascript
javascript结合CSS实现苹果开关按钮特效
2015/04/07 Javascript
关于延迟加载JavaScript
2015/05/05 Javascript
js实现浏览本地文件并显示扩展名的方法
2015/08/17 Javascript
vue.js实现含搜索的多种复选框(附源码)
2017/03/23 Javascript
layer弹窗插件操作方法详解
2017/05/19 Javascript
jQuery简介_动力节点Java学院整理
2017/07/04 jQuery
vue.js框架实现表单排序和分页效果
2017/08/09 Javascript
了解ESlint和其相关操作小结
2018/05/21 Javascript
vue .sync修饰符的使用详解
2018/06/15 Javascript
VUE实现吸底按钮
2021/03/04 Vue.js
[03:30]DOTA2完美“圣”典精彩集锦
2016/12/27 DOTA
python正则匹配抓取豆瓣电影链接和评论代码分享
2013/12/27 Python
Python实现批量转换文件编码的方法
2015/07/28 Python
python opencv之SURF算法示例
2018/02/24 Python
解决python2 绘图title,xlabel,ylabel出现中文乱码的问题
2019/01/29 Python
Python参数传递对象的引用原理解析
2020/05/22 Python
Python configparser模块封装及构造配置文件
2020/08/07 Python
html5 拖拽及用 js 实现拖拽功能的示例代码
2020/10/23 HTML / CSS
澳大利亚现代波西米亚风格女装网站:Bohemian Traders
2018/04/16 全球购物
Maxpeedingrods美国:高性能汽车零件
2020/02/14 全球购物
畜牧兽医本科生的自我评价
2014/03/03 职场文书
2014年团总支工作总结
2014/11/21 职场文书
2015年企业新年寄语
2014/12/08 职场文书
2016年教师寒假学习心得体会
2015/10/09 职场文书
2019森林防火宣传标语大全!
2019/07/03 职场文书