过滤器的基本使用

1.全局过滤器

<body>
    <div id="app">
        <p>{{ msg | msgFormat('大好人', '123') | test }}</p> <!--传入参数-->
    </div>
    <script>
        //定义一个vue全局的过滤器,名为msgFormat
        Vue.filter('msgFormat', function(msg, arg1, arg2) {
            //第一个参数除了可写一个字符串,还可以定义一个正则表达式
            return msg.replace(/SB/g, arg1+arg2);
        })
        //过滤器可以多次调用
        Vue.filter('test', function(msg) {
            return msg+'....';
        })
        var vm = new Vue({
            el: "#app",
            data:{
              msg: '你是SB'
            },
            methods: {}
        });
    </script>
</body>

在这里插入图片描述

2.私有过滤器

<body>
    <div id="app">
        <p>{{ dt | msgFormat }}</p>
    </div>
    <script>
        var vm = new Vue({
            el: "#app",
            data:{
              dt: new Date()
            },
            methods: {},
            filters: {
                msgFormat: function(dateStr, pattern='') {
                    var dt = new Date(dateStr);
                    var y = dt.getFullYear();
                    var m = (dt.getMonth() + 1).toString().padStart(2, '0');
                    var d = dt.getDate().toString().padStart(2, '0');
                    if (pattern.toLowerCase() === 'yyyy-mm-dd') {
                        return `${y}-${m}-${d}`;
                    } else {
                        var hh = dt.getHours().toString().padStart(2, '0');
                        var mm = dt.getMinutes().toString().padStart(2, '0');
                        var ss = dt.getSeconds().toString().padStart(2, '0');
                        return `${y}-${m}-${d} ${hh}:${mm}:${ss}`
                    }
                }
            }
        });
    </script>
</body>

在这里插入图片描述

  • 过滤器调用采用就近原则,先调用私有过滤器,没有私有过滤器再调用全局过滤器
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值