• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

AngularJS过滤器filter用法分析

angularjs 搞代码 4年前 (2021-12-31) 35次浏览 已收录 0个评论

这篇文章主要介绍了AngularJS过滤器filter用法,结合实例形式分析了过滤器filter的功能、分类、使用方法与相关注意事项,需要的朋友可以参考下

本文实例讲述了AngularJS过滤器filter用法。分来源gaodai#ma#com搞*!代#%^码网享给大家供大家参考,具体如下:

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

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

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

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

以上三种场景分别对数据进行了转换/筛选/排序,总而言之就是对数据的格式化,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模板中|左侧的数据,它会自动传入过滤器中

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

   <title>AngularJS过滤器filter入门</title> <p>{{ str | capitalize}}</p><!-- 输出 Hello, Welcome To Bokeyuan! -->

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

更多关于AngularJS相关内容感兴趣的读者可查看本站专题:《AngularJS入门与进阶教程》及《AngularJS MVC架构总结》

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

以上就是AngularJS过滤器filter用法分析的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:AngularJS过滤器filter用法分析

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址