es6的箭头函数中this指向是跟普通function中的this指向不同的,普通function的this指向取决于调用function的对象,

而箭头函数的this指向取决于声明它的对象,看下面这个例子

       var a1 = 1;
            function func1(){
                this.a1 = 2;
                console.log(this.a1);
            }
            var func2 = () =>{
                console.log(this.a1)
            }
            function func3(){
                this.say = () =>{
                    console.log(this.a1)
                }
            }
            new func1();//2
            func2();//1
            new func3().say();//undefined

func1因为是new形式调用的,func1充当了一个构造器的作用,所以this是指向func1所构造的一个实例,因此func1中的this指向func1实例,而非全局作用域

func2是箭头函数,不过要注意func2不能以new的形式调用,而func2是在全局作用域被声明的,所以func2内访问this.a1相当于window.a1即全局变量a1

func3的作用域内声明了名为say的箭头函数,所以以构造器函数形式调用func3时,func3.say方法this指向的是func3的实例,但是func3并没有定义名为a1的成员变量,所以最后打印结果就是undefined了

最新文章

  1. 百度eCharts体验
  2. Spring MVC - 配置Spring MVC
  3. 谈谈Delphi中的类和对象4---类是一种对数据和操作高度的封装机制 && 类是一种代码重用机制
  4. iOS-多线程--介绍NSThread和GCD及其它们的线程通讯示例
  5. android之常用知识点(一)
  6. [Emacs] 常用快捷键-- 生存指南
  7. #pragma 的使用
  8. 利用LRUMap 设计缓存
  9. 学习笔记_Java_day13_JSP三大指令()
  10. Linux + C + Epoll实现高并发服务器(线程池 + 数据库连接池)(转)
  11. c++优先级
  12. AngularJS Change Path Without Reloading
  13. Forget Java to learn Javascript from 0.--Day 1
  14. 如何开发一个微信小程序
  15. Workflow相关表简单分析
  16. flask 登录验证码 字母和数字
  17. 【Quartz】实现接口封装化(二)
  18. Oracle12c版本中未归档隐藏参数
  19. [DEBUG]椭圆的中点Bresenham算法边缘绘制出现错误
  20. 分页功能实现之通过ajax实现表单内容刷新

热门文章

  1. Unsafe例子
  2. dp - 最大子矩阵和 - HDU 1081 To The Max
  3. CTS,CLS,CLR解释
  4. EF Core中的DB First与Code First
  5. SQL索引管理器 - 用于SQL Server和Azure上的索引维护的免费GUI工具
  6. [转]全面认识golang string
  7. 2019-09-17 thinkphp网页静态化
  8. 简洁的 systemd 操作指南Linux下Service文件服务说明(转)
  9. Solr搜索器的特性及相关操作
  10. 关于如何修改一张表中所有行与选定字段的同sql多行语句的添加方法