第十五课 Vue中的过滤器

Vue中的过滤器

Vue2.0以后废除了原始的过滤器,我们可以通过自定义过滤器去进行过滤

自定义过滤器通过属性filter去拓展

基础示例:

复制代码
    <div id="app">
        <h1>{{val | test}}</h1>
    </div>
    <script>
            new Vue({
                el: '#app',
                data: {
                    val: 10
                },
                filters: {
                    test(val){
                         return val > 100? '当前值大于100': '当前值不大于100'
                    }
                }
            })
    </script>  

自定义单向过滤器

1) 通过构造函数构建过滤器

大小写过滤

复制代码
    <div id="app">
        <input type="text" v-model="val">
        原始输入内容:<h1>{{val}}</h1>
        将大写英文转成小写:<h1>{{val | lowCase}}</h1>
        将小写英文转换成大写:<h1>{{val | upCase}}</h1>
    </div>
    <script>
            new Vue({
                el: '#app',
                data: {
                    val: 'Hello World !'
                },
                filters: {
                    lowCase(val){
                         return val.toLowerCase();
                    },
                    upCase(val){
                         return val.toUpperCase();
                    }
                }
            })
    </script> 

2)通过外部单独拓展过滤器

复制代码
<div id="app">
    <input type="text" v-model="val">
    原始输入内容:<h1>{{val}}</h1>
    将大写英文转成小写:<h1>{{val | lowCase}}</h1>
    将小写英文转换成大写:<h1>{{val | upCase}}</h1>
</div>
<script>
        Vue.filter('lowCase', function(val){
            return val.toLowerCase();
        });

        Vue.filter('upCase', function(val){
            return val.toUpperCase();
        })

        new Vue({
            el: '#app',
            data: {
                val: 'Hello World !'
            }
        })
</script>
  1. 关于参数值传递

fiter过滤器默认值第一位是当前的过滤参数,如果在过滤器传入参数,直接在参数集中传入其他参数即可

复制代码
<div id="app">
    原始输入内容:<h1>{{val | deal('Hello ', 'World !')}}</h1>
</div>
<script>
    new Vue({
        el: '#app',
        data: {
            val: 'Bob'
        },
        filters: {
            deal(val, before, after){
                console.log(val);
                console.log(before);
                console.log(after);
                return before + val + after;
            }
        }
    })
</script> 
相关推荐
蔗理苦42 分钟前
2025-09-05 CSS3——盒子模型
前端·css·css3
二川bro1 小时前
第25节:VR基础与WebXR API入门
前端·3d·vr·threejs
上单带刀不带妹2 小时前
Node.js 的模块化规范是什么?CommonJS 和 ES6 模块有什么区别?
前端·node.js·es6·模块化
缘如风2 小时前
easyui 获取自定义的属性
前端·javascript·easyui
诗书画唱2 小时前
【前端教程】JavaScript 实现图片鼠标悬停切换效果与==和=的区别
开发语言·前端·javascript
光影少年2 小时前
前端上传切片优化以及实现
前端·javascript·掘金·金石计划
喜葵2 小时前
前端安全防护深度实践:从XSS到供应链攻击的全面防御
前端·安全·xss
_r0bin_2 小时前
分片上传-
前端·javascript·状态模式
东北南西2 小时前
手写React状态hook
前端·javascript·react.js
诗书画唱2 小时前
【前端教程】JavaScript DOM 操作实战案例详解
开发语言·前端·javascript