定义私有过滤器和基本使用

私有过滤器和全局过滤器的方法和概念都相同,只是一个是全局都可以调用,而私有的只有自己可以调用,

全局过滤器点这里全局过滤器

使用方法也和全局过滤器一致,只是定义的地方不同

全局过滤器是在 script 中 通过Vue.filter 定义

私有过滤器定义方法:

<script>
        let vm = new Vue({
            el:'#app',
            data:{
            
            },
            filters: { // 当前实例私有的过滤器

            }
        })
    </script>

在vm实列中,有和 data 同级的 filters,用来定义当前实例的私有过滤器

    <div id="app">
        <p>{{mes | addStr}}</p>
    </div>

    <script src="./js/vue.js"></script>
    <script>
        let vm = new Vue({
            el:'#app',
            data:{
                mes:"我是一个悲观的人,悲观的人做悲观的事"
            },
            filters: { // 当前实例私有的过滤器
                addStr(data,str="开心"){
                    return data.replace(/悲观/g,str)
                }
            }
        })
    </script>

输出结果为:

image.png


如果页面中 有第二个实例,vm2,去调用 vm 中的过滤器,是调用不到的


如果在页面上有一个全局过滤器,和私有过滤器,是可以同时调用的

 
    <div id="app">
        <p>{{mes | setStr | addStr}}</p>
    </div>

    <script src="./js/vue.js"></script>
    <script>

        Vue.filter('setStr',function(data){
            return data+'我是全局过滤器'
        })

        let vm = new Vue({
            el:'#app',
            data:{
                mes:"我是一个悲观的人,悲观的人做悲观的事"
            },
            filters: { // 当前实例私有的过滤器
                addStr(data,str="开心"){
                    return data.replace(/悲观/g,str)
                }
            }
        })
    </script>

输出结果:

image.png

在调用时我们在前面调用的 全局 ,后面是私有

但输出结果却是 私有过滤器先进行处理

所以,当同时调用全局和私有过滤器时,调用规则是谁离的近先输出谁,

先私有在全局

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值