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>
————————————————
版权声明:本文为CSDN博主「天堂の风」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/ZZQ928000/article/details/105141690/