JavaScript基础之this和箭头函数详析
2019-09-05 09:00
746 查看
箭头函数不会创建自己的this,它只会从自己的作用域链的上一层继承this。
由于箭头函数没有自己的this指针,通过 call() 或 apply() 方法调用一个函数时,只能传递参数(不能绑定this),他们的第一个参数会被忽略。
前言
阅读下面的内容要先看下《你不知道的javascript(上)》中的第二部分:this和对象原型(里面对于this指向的理论部分主要来源于该书)。
问题
这周在写代码的时候,听同事在说箭头函数无法更改this的指向,并且使用下面代码进行验证:
// (1) 使用箭头函数,this一直指向window var a = 0 var obj1 = { a: 1, fn: () => { console.log(this.a) } } obj1.fn() // 结果:0 var obj2 = { a: 2 } obj2.fn = obj1.fn obj2.fn() // 结果:0
// (2)不使用箭头函数,this的指向会更改 var obj3 = { a: 3, fn: function() { console.log(this.a) } } obj3.fn() // 结果:3
第一段代码,无论fn绑定在哪个对象上,this.a始终指向全局的a(在非严格模式下的浏览器中我们可认为是window)
然而,这种说法是有问题(我认为)。
先理解this
this代表什么取决于:
- 调用位置
- 四种绑定规则
var a = 0 test() // 调用位置在此,通过【默认绑定规则】,可知test的this绑定到了window上 function test() { console.log(this) // this是window var obj1 = { a: 1, fn: function() { console.log(this) // this是obj1 console.log(this.a) } } obj1.fn() // 调用位置在此,通过【隐式绑定规则】,可知fn中的this绑定到了obj1上 var obj2 = { a: 2 } obj2.fn = obj1.fn obj2.fn() // 调用位置在此,【隐式绑定规则】,可知fn内的this绑定到了obj2 }
箭头函数中的this
其实这么起标题不太准确(然而想不出好的名字),因为箭头函数是不会创建自己的this的(MDN),那么下面代码的this是来源于哪里的呢?
var obj3 = { a: 3, fn: () => { console.log(this.a) } } obj3.fn() // 调用位置在此,this指向window
arrowFoo1() // (1)此处是调用位置,使用【默认的绑定规则】,this = window function arrowFoo1() { var obj1 = { vv: 'svv1', fn: () => { console.log(this.vv, 'vv的值是') } } // (2)调用位置是此处,若fn不是箭头函数,那么这里也会有自己的this(即【隐式调用规则】,this绑定为obj1),而fn是箭头函数,则它没有this,那么fn内部调用的this是谁? // 这时候需要根据作用域的规则,往外层查找,找到哪里?找到调用obj1.fn的调用栈,即arrowFoo1函数的this,那么从(1)中可知,那个this指向的是window obj1.fn() var obj2 = { vv: 'svv2', } obj2.fn = obj1.fn obj2.fn() } function arrowFoo2() { var vv = '哦哦哦哦哦' console.log(this.vv, 'vv的值是') }
因此,箭头函数里面要是用到了this,那么其实它是通过作用域链,往外进行查找的,找到了就直接返回咯。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- JavaScript学习笔记 ------ this指向和箭头函数的作用
- JavaScript基础 点击div块后背景颜色发生变化 事件的函数参数是this
- javascript基础集锦_箭头函数、generator(六)
- JavaScript基础 点击div块后背景颜色发生变化 事件的函数参数是this
- JavaScript基础知识——函数的 arguments 和 this
- JavaScript 精粹 基础 进阶(6)函数和作用域(函数、this)
- javascript基础之七(函数闭包中this的变化)
- javascript基础修炼(8)——指向FP世界的箭头函数
- JavaScript--箭头函数对this的影响
- javascript this 和 es6 箭头函数this 的理解以及call()、apply()、bind()的用法
- JavaScript 基础(七) 箭头函数 generator Date JSON
- JavaScript箭头函数中的this详解
- 深入理解Javascript箭头函数中的this
- JavaScript基础之箭头函数
- JavaScript基础——创建函数
- ASP.NET AJAX 说明文档->客户端引用->全局命名空间->JavaScript 基础类型扩展->Array 类型扩展->add 函数
- JavaScript基础之匿名立即执行函数
- JavaScript语言基础7---函数的综合练习
- ES6之箭头函数详解(this指向以及要点)
- Javascript中函数调用与this所指对象关系进行了一下总结