Vue filters过滤器

实例

先来看看一段代码理解下
html

<div id="app">
    {{message | filters2| filters3(true,priceCount)}}
</div>

js

var app = new Vue({
    el: "#app",
    data: {
        message: 199,
        priceCount:.8
    },
    filters:{
        filters2:function (arg) {
            console.log("arg:"+arg)
            if(arg>100){
                return arg-8;
            }else {
                return arg;
            }
        },
        filters3:function (arg_1,arg_2,arg_3) {
            var result;
            console.log("arg_1:"+arg_1)
            console.log("arg_2:"+arg_2)
            console.log("arg_3:"+arg_3)
            if(arg_2){
                result = arg_1*arg_3;
                console.log("result"+result);
                return result;
            }else{
                result =arg_1;
                console.log("result"+result);
                return result
            }

        }
    }
});

控制台日志

helloVue.js:17 arg:199
helloVue.js:26 arg_1:191
helloVue.js:27 arg_2:true
helloVue.js:28 arg_3:0.8
helloVue.js:35 result152.8

先来看看两个过滤器的入参
第一个过滤器filters2的入参是199,是Vue实例中绑定的message
第二个过滤器filters3的入参是191、(第一个过滤器返回的值)false(第二个过滤器的第一个入参)、0.8(第二个过滤器的第二个入参)

1、Vue实例中的message是199
2、第一个过滤器,大于100的数减8(理解为满100减8),199-8=191传给第二个过滤器作为第一个参数
3、第二个过滤器,有两个入参,第一个是boolean值(理解为是否打折),第二个是0.8(折扣)。
当第一个入参为true的时候(表示需要打折),191*0.8=152.8(0.8为折扣)

总结

通过过滤器filters我们可以根据业务场景对数据进行处理。
如上一个例子,可以理解成如下业务场景。
1、当商品价格大于100时,可以减8块钱
2、当店铺做活动的时候可以进行打折促销(0.8)
3、最后展示的数值就是用户需要支付的金额

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值