Lao乾妈官方认证唯一女友:D 2022-08-29 21:45 采纳率: 85.7%
浏览 31
已结题

this的指向问题,具体问题在下面的代码注释里

this的指向问题,具体问题在下面的代码注释里
下面是所有的代码了,需要引入一个vue.js

<div id="list">
      <h2>人员列表</h2>
      <input type="text" placeholder="请输入名字" v-model="keyWord" /><br /><br />
      <li v-for="(objP) in filPersons">{{objP.id}}--{{objP.uname}}--{{objP.age}}</li>
    </div>

```javascript
      Vue.config.productionTip = false;
      const vm = new Vue({//----------------vm在这里-----------------------
        el: '#list',
        data: {
          persons: [
            { id: '001', uname: '李常超', age: 18 },
            { id: '002', uname: '李大哥', age: 28 },
            { id: '003', uname: 'LCC', age: 38 },
            { id: '004', uname: 'Lcc', age: 48 },
          ],
          keyWord: '',
},
 computed: {
          filPersons() {
//问题在这里,下面的箭头函数我把它换成普通函数就不行,我想应该是this.keyWord的指向问题错了
//打印this.keyWord的this,发现如果是箭头函数的话指向的是vm,就没问题
            return this.persons.filter((objP) => {
              return objP.uname.indexOf(this.keyWord) !== -1;
            });
//但如果是普通函数的话,打印this.keyWord的this,指向的是window
//所以我的问题是,怎么看出来这两个this的指向的啊?
//如果说箭头函数没有自己的this,往外找的话,不是可以找到filPersons这个方法吗?怎么又往上找到vm了呢?
          /*  return this.persons.filter(function (objP) {
              objP.uname.indexOf(this.keyWord) !== -1;
            }); */
          },
        },
      });

  • 写回答

2条回答 默认 最新

  • 雾里桃花 2022-08-29 22:01
    关注

    filter方法是指向window的,所以你使用普通函数它的this指针是指向window
    箭头函数本身没有this指向,所以会查找外级的函数,vue中所有的方法的this都是被绑定到vue实例上的,统一指向vue实例不管是data函数,还是各个生命周期,还是wacch computed它们的指针全部都背绑定到了vue实例

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 9月6日
  • 已采纳回答 8月29日
  • 创建了问题 8月29日

悬赏问题

  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥170 如图所示配置eNSP
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效
  • ¥15 悬赏!微信开发者工具报错,求帮改
  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果