vue过滤器filters获取不到this对象的解决办法
在data中定义一个熟悉,预先把this存储起来方便使用在调用filters中的方法sum的时候将this传进去即可举个例子用filter计算data中a+b的值<template><div>{{a|sum(that)}}</div></template><script>export default {...
·
原理
- 在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>
更多推荐



所有评论(0)