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 相关文章推荐
setTimeout和setInterval的浏览器兼容性分析
Feb 27 Javascript
用JS写的一个TableView控件代码
Jan 23 Javascript
jQuery的运行机制和设计理念分析
Apr 05 Javascript
SeaJS 与 RequireJS 的差异对比
Dec 08 Javascript
jQuery+easyui中的combobox实现下拉框特效
Feb 27 Javascript
如何利用JS通过身份证号获取当事人的生日、年龄、性别
Jan 22 Javascript
Easyui Treegrid改变默认图标的方法
Apr 29 Javascript
使用JSON作为函数的参数的优缺点
Oct 27 Javascript
web前端开发中常见的多列布局解决方案整理(一定要看)
Oct 15 Javascript
js传递数组参数到后台controller的方法
Mar 29 Javascript
Vue实现按钮旋转和移动位置的实例代码
Aug 09 Javascript
Vue-cli3.X使用px2 rem遇到的问题及解决方法
Aug 08 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设计模式 php实现桥梁模式(bridge)
2015/12/07 PHP
YII2.0之Activeform表单组件用法实例
2016/01/09 PHP
基于JQuery实现的类似购物商城的购物车
2011/12/06 Javascript
打开新窗口关闭当前页面不弹出关闭提示js代码
2013/03/18 Javascript
关于js中for in的缺陷浅析
2013/12/02 Javascript
点击页面任何位置隐藏div的实现方法
2016/09/05 Javascript
简单实现jQuery多选框功能
2017/01/09 Javascript
jQuery实现鼠标滑过预览图片大图效果的方法
2017/04/26 jQuery
Angular.js中$resource高大上的数据交互详解
2017/07/30 Javascript
纯js实现图片匀速淡入淡出效果
2017/08/22 Javascript
详解Vue.js组件可复用性的混合(mixin)方式和自定义指令
2017/09/06 Javascript
nodejs中express入门和基础知识点学习
2018/09/13 NodeJs
详解如何制作并发布一个vue的组件的npm包
2018/11/10 Javascript
Vue.js特性Scoped Slots的浅析
2019/02/20 Javascript
JavaScript静态作用域和动态作用域实例详解
2019/06/17 Javascript
layer弹出层自适应高度,垂直水平居中的实现
2019/09/16 Javascript
Vue Extends 扩展选项用法完整实例
2019/09/17 Javascript
jQuery实现tab栏切换效果
2020/12/22 jQuery
python实现井字棋游戏
2020/03/30 Python
python3 实现的人人影视网站自动签到
2016/06/19 Python
python数据类型_字符串常用操作(详解)
2017/05/30 Python
Python xlwt设置excel单元格字体及格式
2020/04/18 Python
对Tensorflow中的矩阵运算函数详解
2018/07/27 Python
django商品分类及商品数据建模实例详解
2020/01/03 Python
CSS教程:CSS3圆角属性
2009/04/02 HTML / CSS
HTML5新增的8类INPUT输入类型介绍
2015/07/06 HTML / CSS
德国机场停车位比较和预订网站:Ich-parke-billiger
2018/01/08 全球购物
解决python 输出到csv 出现多空行的情况
2021/03/24 Python
毕业学生推荐信
2013/12/01 职场文书
信用社员工先进事迹材料
2014/02/04 职场文书
幼儿园清明节活动总结
2014/07/04 职场文书
无犯罪记录证明范本
2014/09/15 职场文书
清明节文明祭祀倡议书
2015/04/28 职场文书
2015年税务稽查工作总结
2015/05/26 职场文书
2019年学校消防安全责任书(2篇)
2019/10/09 职场文书
win11开机发生死循环重启怎么办?win11开机发生死循环重启解决方法
2022/08/05 数码科技