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

Vue的全局过滤器和私有过滤器的实现

vue 搞代码 4年前 (2022-01-08) 14次浏览 已收录 0个评论

这篇文章主要介绍了Vue的全局过滤器和私有过滤器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

Vue允许自定义过滤器 可被用作一些常见的文本格式化

过滤器可以用在两个地方:mustache插值表达式 和 v-bind表达式

过滤器应被添加在JavaScript表达式的尾部 由“管道”符指示(管道符就是一个竖杠:|)

一、全局过滤器

全局过滤器调用时的基本格式:

通过管道符[|]来进行过滤 例如{{name | nameOpe}}
定义过滤器的语法:Vue.filter("过滤器名称",处理函数)

处理函数的第一个参数已被固定了 是data 即管道符前面传递的数据
若要添加其它入参 只能添加在data的后面了

 Vue.filter("",function(data) { return data+"123"; })

(上述例子中 该过滤器的功能就是给过滤器前面的数据加上”123″字符串)

一个值得注意的地方是:过滤器并没有修改原数据 只是在输出之前进行了一层处理

 <div id="app"> <p>{{msg | msgFormat}}</p></div>
 

过滤器也可以传入参数 且还能传多个参数

 <div id="app"> <!-- 过滤器也可以传参 还能传多个参数 --><p>{{msg | msgFormat("豪哥","111")}}</p></div>
 

还能多次调用过滤器 被调用的过滤器会按顺序执行

 <div id="app"> <!-- 调用多个过滤器 --><p>{{msg | msgFormat("豪哥","111") | test}}</p></div>
 

这两个过滤器组合起来 顺序执行 输出结果就是:

二、私有过滤器

全局过滤器是能够被所有的Vue实例共享 因而得名
那么 同理 私有过滤器就是只能被定义的那个Vue实例使用

过滤器的调用顺序 采用的是就近原则
即 若有私有过滤器 则会优先使用私有过滤器 若没有私有过滤器 则会使用全局过滤器

每个过滤器有其自己的【名称】和【处理函数】

定义私有过滤器的时候 也是在Vue实例里定义的
有个filters属性专门用来定义私有过滤器
格式就是:过滤器名:方法

以一个日期格式转换过滤器作为例子:

 <div id="app2"> <h3>{{date | dateFormat}}</h3></div>
 // 自定义私有过滤器 var vm2=new Vue({ el:'#app2', data:{ date:new Date() }, methods:{}, // 定义私有过滤器 filters:{ dateFormat:function(dateStr,pat<strong>本文来源gaodai#ma#com搞@@代~&码*网2</strong>tern="") { var dt=new Date(dateStr); var year=dt.getFullYear(); var month=dt.getMonth()+1; var day=dt.getDate(); if (pattern.toLowerCase()==="yyyy-mm-dd") { return `${year}-${month}-${day}`; } else { var hour=dt.getHours(); var minute=dt.getMinutes(); var second=dt.getSeconds(); return `${year}-${month}-${day} ${hour}:${minute}:${second}`; } } } })

以上就是Vue的全局过滤器和私有过滤器的实现的详细内容,更多请关注gaodaima搞代码网其它相关文章!


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

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

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

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

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