学堂 学堂 学堂公众号手机端

vue中如何定义私有过滤器,相比全局过滤器有何不同

lewis 1年前 (2024-04-16) 阅读数 11 #技术
这篇文章给大家介绍了“vue中如何定义私有过滤器,相比全局过滤器有何不同”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。
   



  私有过滤器和全局过滤器的方法和概念都相同,只是一个是全局都可以调用,而私有的只有自己可以调用,  
  全局过滤器点这里全局过滤器   
使用方法也和全局过滤器一致,只是定义的地方不同   全局过滤器是在 
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>
输出结果为: 如果页面中 有第二个实例, 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>
输出结果: 总结: 在调用时我们在前面调用的 全局 ,后面是私有 但输出结果却是 私有过滤器先进行处理 所以,当同时调用全局和私有过滤器时,调用规则是谁离的近先输出谁, 先私有在全局
关于“vue中如何定义私有过滤器,相比全局过滤器有何不同”就介绍到这了,如果大家觉得不错可以参考了解看看,如果想要了解更多,欢迎关注博信,小编每天都会为大家更新不同的知识。
版权声明

本文仅代表作者观点,不代表博信信息网立场。

热门