Vue使用filters过滤时不能使用this的解决办法——两次遇到了,一定要记住奥~

在Vue中遇到使用filters过滤时this指针无法指向Vue实例的问题,可以通过将需要的上下文信息作为参数传递给filter解决。修改后的filter接受一个额外的list参数,然后在过滤函数内部使用这个list,避免了对this的依赖。更新后的HTML模板中,将categoryList传入getName过滤器,成功避免了this引用错误。
摘要由CSDN通过智能技术生成

Vue使用filters过滤时不能使用this的解决办法

script部分

filters: {
  getName(val) {
    for (let i = 0; i < this.list.length; i++) {
      let id = Object.keys(this.list[i])[0];
      if (id === val) {
        return this.list[i][val];
      }
    }
  }
},

html部分代码

<span>{{scope.row.spus[0].categoryId | getName}}</span>

在使用filter过滤器的时候,使用的方式就是使用管道符。管道符|前面是参数,后面是过滤器。
在使用的时候,会报错:this.list报错,this不能指代vue。

如果在filter中使用this的话,则需要通过过滤器将参数传递过去。

filters: {
  getName(val, list) {
    for (let i = 0; i < list.length; i++) {
      let id = Object.keys(list[i])[0];
      if (id === val) {
        return list[i][val];
      }
    }
  }
},

html部分代码

<span>{{scope.row.spus[0].categoryId | getName(categoryList)}}</span>

问题解决!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶浩成520

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值