vue自定义过滤器

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

模板内容
<div class="test">
    <p>{{message | sum}}</p>
    <!--过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算。-->
    <p>{{message | cal 10 20}}</p>  
     <!--添加两个过滤器,注意不要冲突-->
    <p>{{message | sum | currency }}</p>
    <!--用户从input输入的数据在回传到model之前也可以先处理,此处使用的是vue提供的双向过滤器,针对input-->
    <input type="text" v-model="message | change"> 
</div>
//全局方法 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 在更新 `<input>` 元素之前格式化值
    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
    }
})

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

<div class="test">
       <p>{{message | sum}}</p>
       <!--过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算。-->
       <p>{{message | cal 10 20}}</p>  
       <!--添加两个过滤器,注意对数据的操作不要冲突-->
       <p>{{message | sum | currency }}</p> 
       <!--用户从input输入的数据在回传到model之前也可以先处理-->      
       <input type="text" v-model="message | change"> 
</div>
Vue.filter("change", {
    read: function (value) { 
        // model -> view 在更新 `<input>` 元素之前格式化值
        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;
        }
    }
})   
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容