Vue中filter过滤器的使用方法

举报
青年码农 发表于 2022/08/24 22:16:39 2022/08/24
【摘要】 Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示: <!-- 在双花括号中 -->{{ m...

Vue.js 允许你自定义过滤器,可被用于一些常见的文本格式化。过滤器可以用在两个地方:双花括号插值和 v-bind 表达式 (后者从 2.1.0+ 开始支持)。过滤器应该被添加在 JavaScript 表达式的尾部,由“管道”符号指示:


   
  1. <!-- 在双花括号中 -->
  2. {{ message | capitalize }}
  3. <!-- 在 `v-bind` 中 -->
  4. <div v-bind:id="rawId | formatId"></div>

我们先看上面的官方解释,也可以简单理解为过滤器是对即将显示的数据做进一步的筛选处理,然后进行显示,值得注意的是过滤器并没有改变原来的数据,只是在原数据的基础上产生新的数据。

过滤器分为两种:

  • 局部过滤器:只允许在当前组件中使用

  • 全局过滤器:所有组件都可以使用

局部过滤器

定义也很简单,先来说下组件内的过滤器。


   
  1. export default {
  2.     data () {
  3.         return {
  4.             msg: 'hello world'
  5.         }
  6.     },
  7.     //定义局部过滤器。只能在当前 vue 对象中使用
  8.     filters: {
  9.         dataFormat: (msg, a) => { // msg表示要过滤的数据,a表示传入的参数
  10.             return msg + a;
  11.         }
  12.     }
  13. }

组件使用方法

<p>{{ msg | dataFormat('!')}}</p>
  

这里面有几个注意的点

  • 当全局过滤器和局部过滤器重名时,会采用局部过滤器,即:局部过滤器优先于全局过滤器被调用

  • 一个表达式可以使用多个过滤器,其执行顺序从左往右,前一个过滤器的结果作为后一个过滤器的被处理数据,所以要注意使用顺序

全局过滤器

全局过滤器我们使用Vue脚手架搭建的项目作为演示

一般我们会把一些通用的方法封装到一个js文件,这里我们也一样,有个utils.js文件,导出两个方法


   
  1. export const dataFormat = (val) => {
  2.     // 里面是逻辑,这里简单返回
  3.     return val + "!"
  4. }
  5. export const dataFormat1 = (val) => {
  6.     // 里面是逻辑,这里简单返回
  7.     return val + "!!!"
  8. }

在 main.js文件中引用(假设utils.js文件和main.js文件同目录)


   
  1. // 过滤器
  2. import * as filters from './utils'
  3. Object.keys(filters).forEach(key => {
  4.     Vue.filter(key, filters[key])
  5. })

在项目任意组件使用


   
  1. <!-- 在双花括号中 -->
  2. <p>{{ msg | dataFormat}}</p> 
  3. <!-- 在 `v-bind` 中 -->
  4. <div v-bind:id="msg | dataFormat"></div>

全局的过滤器要比局部过滤器使用的更广泛一些,说白了我们为什么要使用过滤器,其实就跟使用函数是一样,我们想把一些方法封装,供其它组件使用,这样调用起来方便,开发更快捷。

文章来源: blog.csdn.net,作者:NMGWAP,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/NMGWAP/article/details/125067188

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。