vue中可以自定义过滤器,用于{{插槽}}和v-bind表达式。
// 双花括号插槽
{{ message | capitalize }}
// v-bind
<div v-bind:id="rawId | formatId"></div>
- 全局定义
(1) 全局方法 Vue.filter() 注册一个自定义过滤器,必须放在Vue实例化前面
(2) 过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算
Vue.filter('filterA', value => {
if (!value) return ''
value = value.toString()
return value.replace(
value.substr(1, value.length - 1),
'*'.repeat(value.length - 2)
) + value.substr(-1, 1)
})
Vue.filter("change", {
read(value) {
return value;
},
write(newVal,oldVal) {
console.log("newVal:"+newVal);
console.log("oldVal:"+oldVal);
return newVal;
}
});
new Vue({
// ...
})
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>vue自定义过滤器</title>
<script src="../js/vue.js" type="text/javascript" charset="utf-8"></script>
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
</head>
<body>
<div class="test">
<p>{{message | sum}}</p>
<p>{{message | cal 10 20}}</p> <!--过滤器函数始终以表达式的值作为第一个参数。带引号的参数视为字符串,而不带引号的参数按表达式计算。-->
<p>{{message | sum | currency }}</p> <!--添加两个过滤器,注意不要冲突-->
<input type="text" v-model="message | change"> <!--用户从input输入的数据在回传到model之前也可以先处理-->
</div>
<script type="text/javascript">
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;
}
}
});
</script>
</body>
</html>
- 局部注册filter
filters: {
license (value) {
return (
value.replace(
value.substr(1, value.length - 1),
'*'.repeat(value.length - 2)
) + value.substr(-1, 1)
)
},
},
- 串联过滤器
{{ message | filterA | filterB }}
filterA 被定义为接收单个参数的过滤器函数,表达式 message 的值将作为参数传入到函数中。然后继续调用同样被定义为接收单个参数的过滤器函数 filterB,将 filterA 的结果传递到 filterB 中。