html 函数里面this,ES6箭头函数中this指向谁?

f3e979b12d75c81591b1cdc7b58bb5a2.png

ES6箭头函数中this

(1)默认指向定义它时,所处上下文的对象的this指向。即ES6箭头函数里this的指向就是上下文里对象this指向,偶尔没有上下文对象,this就指向window

(2)即使是call,apply,bind等方法也不能改变箭头函数this的指向

一些实例加深印象

(1)hello是全局函数,没有直接调用它的对象,也没有使用严格模式,this指向windowfunction hello() {

console.log(this); // window

}

hello();

(2)hello是全局函数,没有直接调用它的对象,但指定了严格模式('use strict'),this指向undefinedfunction hello() {

'use strict';

console.log(this); // undefined

}

hello();

(3)hello直接调用者是obj,第一个this指向obj,setTimeout里匿名函数没有直接调用者,this指向windowconst obj = {

num: 10,

hello: function () {

console.log(this); // obj

setTimeout(function () {

console.log(this); // window

});

}

}

obj.hello();

(4)hello直接调用者是obj,第一个this指向obj,setTimeout箭头函数,this指向最近的函数的this指向,即也是objconst obj = {

num: 10,

hello: function () {

console.log(this); // obj

setTimeout(() => {

console.log(this); // obj

});

}

}

obj.hello();

(5)diameter是普通函数,里面的this指向直接调用它的对象obj。perimeter是箭头函数,this应该指向上下文函数this的指向,这里上下文没有函数对象,就默认为window,而window里面没有radius这个属性,就返回为NaN。const obj = {

radius: 10,

diameter() {

return this.radius * 2

},

perimeter: () => 2 * Math.PI * this.radius

}

console.log(obj.diameter()) // 20

console.log(obj.perimeter()) // NaN

更多web开发知识,请查阅 HTML中文网 !!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值