vue自定义过滤器

Vue的自定义过滤器有两种:全局过滤器和内部过滤器
全局过滤器定义在vue实例化之前

模板内容

{{message | sum}}

{{message | cal 10 20}}

{{message | sum | currency }}

//全局方法 Vue.filter() 注册一个自定义过滤器
Vue.filter("sum", function(value) {   
    return value + 4;
});

Vue.filter('cal', function (value, begin, xing) {   
    return value + begin + xing;
});

Vue.filter("change", {
    // model -> view 在更新 `` 元素之前格式化值
    read: function (value) { 
        return value;
    },
    // view -> model  在写回数据之前格式化值
    write: function (newVal,oldVal) {
        console.log("newVal:"+newVal); 
        console.log("oldVal:"+oldVal);
        return newVal;
    }
});

var myVue = new Vue({
    el: ".test",
    data: {
        message:12
    }
})

内部过滤器注册在实例内部,仅在注册它的实例里可用

{{message | sum}}

{{message | cal 10 20}}

{{message | sum | currency }}

Vue.filter("change", {
    read: function (value) { 
        // model -> view 在更新 `` 元素之前格式化值
        return value;
    },
    write: function (newVal,oldVal) { 
        // view -> model  在写回数据之前格式化值
        console.log("newVal:"+newVal); 
        console.log("oldVal:"+oldVal);
        return newVal;
    }
});

var myVue = new Vue({
    el: ".test",
    data: {
        message:12
    },
    filters: {
        sum: function (value) {
            return value + 4;
        },
        cal: function (value, begin, xing) {
            return value + begin + xing;
        }
    }
})   

你可能感兴趣的:(vue自定义过滤器)