vue过滤器filters获取不到this对象的解决办法
原理[*]在data中定义一个属性that,把this存储到that中
[*]在调用filters中的方法sum的时候将that传进去即可
下面举个例子用filters计算data中 a+b 的值
注意:filters中的sum方法的第一个参数是|左边那个a,第二个参数才是括号写的that
<template>
<div>{{a|sum(that)}}</div>
</template>
<script>
export default {
name: "test",
data() {
return {
that: this,
a: 1,
b: 2
}
},
filters: {
sum(a, that) {
console.log(that);
return a + that.b;
}
},
}
</script>
页:
[1]