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;
        }
    }
})   
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容