js中this的指向

一、全局函数
指向window对象

 console.log(this); //window
 function fn() {
   console.log(this); //winsow
}
 fn();

二、构造函数
指向实例对象

function Person(name, age) {
      console.log(this);//指向zs/ls
      this.name = name;
      this.age = age;
    }
    var zs = new Person('zhangsan', 18);
    var ls = new Person('lisi', 20);

三、对象的方法
指向对象

var obj = {
      fn: function () {
        console.log(this);
        console.log(this === obj) //true
      }
    }
    obj.fn();

四、事件处理函数
指向事件源对象

 var btn = document.querySelector('#btn');
    btn.onclick = function () {
      console.log(this); //指向btn
    }
var btn = document.querySelector('#btn');
    btn.addEventListener('click', function () {
      console.log(this); //指向btn
    })

五、定时器回调函数
指向window对象

  setTimeout(function () {
      console.log(this); //window
    }, 1000)

六、箭头函数
箭头函数中不绑定this,箭头函数中的this指向它所定义的位置,可以理解为,定义箭头函数中的作用域的this指向谁,它就指向谁

setTimeout(() => {
      console.log(this);//window
    }, 1000)
 const obj = {
      name: 'zhangsan'
    }
    function fn() {
      console.log(this); //obj
      return () => {
        console.log(this) //obj
      }
    }
    const resFn = fn.call(obj);
    resFn();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值