进阶路上有你我-相互相持篇之ES6里箭头函数里的this指向问题
首先复习下普通函数里的this指向:
 function test(){
     console.log(this)
 }
 test()
你会秒杀的毫无疑问的回答:window,针对普通函数:谁调用了函数 函数里的this就指向谁,test()等价于window.test(),所以是window
var name="outername"
var o={
name:"innername",
getname:function(){
console.log(this.name)
}
}
o.getname()
这个是普通函数,谁调用了函数 函数里的this就指向谁,o.getname(),调用这个getname函数的是o这个对象,这个o对象下面有name:"innername",所以打印出的是 "innername"
怎么还不见ES6里的箭头函数呢?别急马上登场:看我变身
var name="outername"
var o={
name:"innername",
getname:()=>{
console.log(this.name)
}
}
o.getname()
哇,箭头函数出来了,o.getname()执行后,因为箭头函数坐镇,我不敢轻易的说,因为调用getname()的是o对象,所以this指向o对象,哦NO,可是人家不是普通函数,人家是箭头函数,哪就猜相反的那个var name="outername",它会打印外面的那个name("outername"),恭喜你,答对了,原因下面会讲解。
var name="outername"
var o={
name:"innername",
getname:function(){
return ()=>this.name }
}
console.log(o.getname()())
箭头函数继续出现,那么这个会打印出什么呢?不想猜的我直接敲出代码打印出来答案:"innername",为什么?箭头函数的this对象:就是定义时所在的对象,而不是使用时所在的对象,也就是根据外层(函数或者全局)作用域来决定this,再最后个例子一并总结.
var name="outername"
var o={
name:"innername",
getname:function(){
setTimeout(()=>console.log(this.name),1000) }
}
o.getname()
待我先总结完后自己可以先去猜下没有给出答案的答案.
总结:
普通函数this指向:谁调用了函数 函数里的this就指向谁
箭头函数的this指向:就是定义时所在的对象,而不是使用时所在的对象,也就是根据外层(函数或者全局)作用域来决定this
调用的函数类型:
①箭头函数:this指向window
②普通函数:this指向调用这个普通函数的对象,可能这个普通函数里有箭头函数,否管它,即使这个普通函数里有箭头函数,这个箭头函数的this依旧是调用这个普通函数的对象
小结以上调用的函数是普通函数缺内嵌箭头函数的例子:
var name="outername"
var o={
name:"innername",
getname:function(){
return ()=>this.name }
}
console.log(o.getname()())
var name="outername"
var o={
name:"innername",
getname:function(){
setTimeout(()=>console.log(this.name),1000) }
}
o.getname()
this对象的指向是可变的,但是在箭头函数中,它是固定的。
 function foo() {
   setTimeout(() => {
     console.log('id:', this.id);
   }, 100);
 }
 var id = 21;
 foo.call({ id: 42 });
 // id: 42
上面代码中,setTimeout的参数是一个箭头函数,这个箭头函数的定义生效是在foo函数生成时,而它的真正执行要等到 100 毫秒后。如果是普通函数,执行时this应该指向全局对象window,这时应该输出21。但是,箭头函数导致this总是指向函数定义生效时所在的对象(本例是{id: 42}),所以输出的是42。
希望此篇认清ES6箭头函数里的this指向,对你有用。
进阶路上有你我-相互相持篇之ES6里箭头函数里的this指向问题的更多相关文章
- iOS进阶指南试读之UI篇
		iOS进阶指南试读之UI篇 UI篇 UI是一个iOS开发工程师的基本功.怎么说?UI本质上就是你调用苹果提供给你的API来完成设计师的设计.所以,想提升UI的功力也很简单,没事就看看UIKit里的各个 ... 
- NodeJS学习笔记 进阶 (12)Nodejs进阶:crypto模块之理论篇
		个人总结:读完这篇文章需要30分钟,这篇文章讲解了使用Node处理加密算法的基础. 摘选自网络 Nodejs进阶:crypto模块之理论篇 一. 文章概述 互联网时代,网络上的数据量每天都在以惊人的速 ... 
- 深入理解this机制系列第三篇——箭头函数
		× 目录 [1]痛点 [2]解决 [3]基本用法[4]回调函数[5]注意事项 前面的话 this机制与函数调用有关,而作用域则与函数定义有关.有没有什么是可以将this机制和作用域联系起来的呢?本文将 ... 
- 和S5933比较起来,开发PLX9054比较不幸,可能是第一次开发PCI的缘故吧。因为,很多PCI的例子都是对S5933,就连微软出版的《Programming the Microsoft Windows Driver Model》都提供了一个完整的S5933的例子。 在这篇有关DDK的开发论文里。
		和S5933比较起来,开发PLX9054比较不幸,可能是第一次开发PCI的缘故吧.因为,很多PCI的例子都是对S5933,就连微软出版的<Programming the Microsoft Wi ... 
- 【进阶3-2期】JavaScript深入之重新认识箭头函数的this(转)
		这是我在公众号(高级前端进阶)看到的文章,现在做笔记 https://github.com/yygmind/blog/issues/21 上篇文章详细的分析了各种this的情况,看过之后对this的概 ... 
- Java进阶 JVM 内存与垃圾回收篇(一)
		JVM 1. 引言 1.1 什么是JVM? 定义 Java Vritual Machine - java 程序的运行环境(Java二进制字节码的运行环境) 好处 一次编译 ,到处运行 自动内存管理,垃 ... 
- labview从入门到出家5(进阶篇)--程序调试以及labview函数库的运用
		跟了前面几章的操作流程,相信大家对labview有了一定的认识.其实只要了解了labview的编程思路,再熟悉地运用各个变量,函数以及属性,那么我们就可以打开labview的大门了.跟其他编程语言一样 ... 
- [Android进阶]Binder学习(初始篇)
		Android中Binder学习(初始篇) 本篇博客学习自侯亮的博客.地址为: 红茶一杯话Binder 1 什么是Binder? 简单地说.Binder是Android平台上的一种跨进程交互技术. 该 ... 
- GitHub进阶之利用Git远程仓库篇
		#在上一篇文章,相信大家对GitHub已经有了一个基础的理解 接下来我们来学习一下如何利用git来远程仓库 一,git是什么 git:一个免费的开源版本控制软件 用途:利用Git管理GitHub上的代 ... 
随机推荐
- vim 加密(crypt)文本文档
			算法 vim7.3版本支持两种加密方式——PKzip算法(已知有缺陷的).Blowfish算法(从7.3版本开始支持).Blowfish2算法(从7.4.399版本开始支持)而vim -x 默认采用P ... 
- JavaScript中易混淆的DOM属性及方法对比
			JavaScript中易混淆的DOM属性及方法对比 ParentNode.children VS Node.prototype.childNodes ParentNode.children:该属性继承 ... 
- 首次使用AndroidStudio创建hello world遇到的坑!(Mac系统下)
			第一次用AS,且不说它SDK配置的琐碎,光建立第一个简单的HelloWorld项目的配置包问题就把我卡了一天.这个坑必须记录一下, 
- USB接口禁用与启用
			前几天闺蜜淘了一台小本,但是发现计算机USB接口是禁用的,有点头疼,所以问了万能的度娘,找到了n种办法.不过这一种是适用于我的情况,简单记录一下. 解决方法:(主要就是修改注册表) 1.打开注册表编辑 ... 
- postman导入csv文件,批量运行
			1.设置csv文件,第一行必须标明变量名 2.postman参数化设置 3.批量 run即可 
- UVa——1600(巡逻机器人)
			迷宫求最短路的话一般用bfs都可以解决,但是这个加了个状态,那么就增加一个维度,用来判断k的值.比较简单的三维bfs.写搜索题的话一定要注意细节.这个题花了好长的时间.因为k的原因,一开始用了k的原因 ... 
- cf——C. Serval and Parenthesis Sequence
			括号正确匹配问题,应该不难 #include <iostream> #include <cstring> #include <string> #include &l ... 
- HTML5网页制作(3)
			今天,就开始嵌入图片以及创建图片分区的学习吧! 这两张图片其实是我用HTML5写的(纯粹当做笔记来记了),以上就是今天要学的一些内容 下面是我今天敲的代码: [冒泡]林北的爸爸 2019/4/29 ... 
- 你好git
			在老师的推荐下,这次我第一次打开了github,作为一个菜鸟,对于这些功能还是有些新奇的,所以也摸索了很久. GIthub是一个基于git的社会代码分享社区,可以建立公开的,免费的分享代码,也可以关注 ... 
- vc6.0问题
			1.VC6不自动提示函数的参数 是工程中的.ncb文件有问题,把这个文件删除就正常了. 2.设置代码提示快捷键 Tools-->定制-->弹出框,按照下图设置 3.报错 (1)ident ... 
