js中this在各种环境下的指向和案例

js中this在各种环境下的指向和案例

1、全局环境

在全局环境中,this指向全局对象(浏览器中是window对象,Node.js中是global对象)。

console.log(this); // 输出全局对象,如window或global

2、普通函数环境

在函数中,this的指向取决于函数的调用方式。

  • 如果函数作为普通函数调用,this指向全局对象。

例如:

function foo() {
  console.log(this);
}

foo(); // 输出全局对象,如window或global


//即使是嵌套的函数, this 也是指向全局对象
function outer() {
  function inner(){
    console.log(this);	//window或global
  }
  inner();
};   
outer();
  • 但如果函数作为对象方法调用,this指向调用该方法的对象。
    例如:
var obj = {
  foo: function() {
    console.log(this);
  }
};

obj.foo(); // 输出obj对象
  • 如果函数使用构造函数方式调用,this指向新创建的对象。
    例如:
function Foo() {
  console.log(this);
}

var obj = new Foo(); // 输出新创建的对象  Foo {}
  • 如果函数使用call、apply、bind方法调用,this指向作为参数传递的对象。
    例如
function foo() {
  console.log(this);
}

var obj = {};
foo.call(obj); // 输出obj对象 {}

3、箭头函数环境

箭头函数内部的this指向定义时所在的上下文,而不是调用时所在的上下文,也可以说是this为父级指向。
例如:

var obj = {
  foo: function() {
  //1
    var arrowFunc = () => {
      console.log(this);//此时this指向为上一层也就是注释1处,则输出obj对象
    }
    arrowFunc();
  }
};

obj.foo(); // 输出obj对象 {foo: ƒ}

注意,若此例子中arrowFunc改为普通函数,那就是在普通函数中调用,此时this就为全局对象window或global

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值