Vue中的过滤器(filter)详解
官方文档:https://cn.vuejs.org/v2/guide/filters.html
在官方文档中,是这样说明的:可被用于一些常见的文本格式化,vue中过滤器的作用可被用于一些常见的文本格式化。(也就是修饰文本,但是文本内容不会改变)
个人觉得称它为加工车间会更加贴切一些,过滤器可以用来筛选出符合条件的,丢弃不符合条件的;加工车间既可以筛选,又可以对筛选出来的进行加工。
过滤器使用位置
过滤器可以用在两个地方:双花括号插值和 v-bind
表达式 (后者从 2.1.0+ 开始支持)
示例:
<template> <div class="test"> <div :id="rawId">{{rawId}}</div> <!-- 以下v-bind可省略,即v-bind:id可简写为:id --> <div v-bind:id="rawId|filter_formatId">{{rawId|filter_formatId}}</div> </div> </template> <script> export default { data() { return { rawId: 1 }; }, filters: { filter_formatId(value) { return value * 10; } } }; </script> <style lang="scss" scoped> .test { color: black; } </style>
全局过滤器、局部过滤器
全局过滤器:
在main.js中写入:
Vue.filter('filter_addPricePrefix', function (value) { return "¥" + value; })
局部过滤器:
在vue示例中写入:
<template> <div class="test"> <p>{{price}}</p> <p>{{price | filter_addPricePrefix}}</p> </div> </template> <script> export default { data() { return { price: 100 }; }, filters: { filter_addPricePrefix(value) { return "¥" + value; } } }; </script> <style lang="scss" scoped> .test { color: black; } </style>
过滤器中传入多个参数:
过滤器是 JavaScript 函数,因此可以接收参数:
{{ message | filterA('arg1', arg2) }}
这里,
filterA
被定义为接收三个参数的过滤器函数。其中message
的值作为第一个参数,普通字符串'arg1'
作为第二个参数,表达式arg2
的值作为第三个参数。
<template> <div class="test"> <!-- 要过滤的数据,永远是第一个参数;通过filter函数,传递的参数,依次排在后面。 --> <p>{{ new Date() | filter_dateFormat }}</p> <p>{{ new Date() | filter_dateFormat('YYYY-MM-DD') }}</p> <p>{{ new Date() | filter_dateFormat('YYYY-MM-DD', count) }}</p> </div> </template> <script src="https://cdn.bootcss.com/moment.js/2.24.0/moment.js"></script> <script> export default { data() { return { count: 10 }; }, filters: { filter_dateFormat(date, format, count) { return ( moment(date).format(format || "YYYY-MM-DD HH:mm:ss") + (count ? " -- " + count : "") ); } } }; </script> <style lang="scss" scoped> .test { color: black; } </style>
多个过滤器串联:
{{ message | filterA | filterB }}
在这个例子中,
filterA
被定义为接收单个参数的过滤器函数,表达式message
的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数filterB
,将filterA
的结果传递到filterB
中。
<template> <div class="test"> <p>{{price}}</p> <p>{{price | filter_addPricePrefix}}</p> <p>{{price | filter_addPricePrefix |filter_addPriceSuffix}}</p> </div> </template> <script> export default { data() { return { price: 100 }; }, filters: { filter_addPricePrefix(value) { return "¥" + value; }, filter_addPriceSuffix(value) { return value + "元"; } } }; </script> <style lang="scss" scoped> .test { color: black; } </style>
注意:
过滤器中通过this是获取不到vue实例的!!!在其中发起http请求也会失败,因此,为了获取后台数据,我们可以在mounted中先获取tableData,然后,把这个tableData作为过滤器的第二个参数进行传递!!!!
到此这篇关于Vue中的过滤器(filter)的文章就介绍到这了,更多相关Vue中的过滤器内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
vue+watermark-dom实现页面水印效果(示例代码)
watermark.js 是基于 DOM 对象实现的 BS 系统的水印,确保系统保密性,安全性,降低数据泄密风险,简单轻量,支持多属性配置,本文将通过 vue 结合 watermark-dom 库,教大家实现简单而有效的页面水印效果,感兴趣的朋友跟随小编一起看看吧2024-07-07Element-UI中关于table表格的那些骚操作(小结)
这篇文章主要介绍了Element-UI中关于table表格的那些骚操作(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2019-08-08Vue v2.4中新增的$attrs及$listeners属性使用教程
这篇文章主要给大家介绍了关于Vue v2.4中新增的$attrs及$listeners属性的使用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。2018-01-01Vue Element前端应用开发之动态菜单和路由的关联处理
这篇文章主要介绍了Vue Element前端应用开发之动态菜单和路由的关联处理,对vue感兴趣的同学,可以参考下2021-05-05
最新评论