深入理解JavaScript中的箭头
箭头函数可以使我们的代码更加简洁,如下:
var sum = (a,b) => a+b;
JavaScript 充满了我们需要编写在其他地方执行的小函数的情况。
例如:
- arr.forEach(func) —— forEach 对每个数组元素都执行 func 。
 - setTimeout(func) —— func 由内建调度器执行。
 
……还有更多。
JavaScript 的精髓在于创建一个函数并将其传递到某个地方。 在这样的函数中,我们通常不想离开当前上下文。这就是箭头函数的主战场啦。
箭头函数没有 this 。如果访问 this ,则会从外 部获取。
const group = {
  title: "Our Group",
  students: ["John", "Pete", "Alice"],
  showList() {
    this.students.forEach((student) => console.log(`${this.title}:${student}`));
  },
};
group.showList();
如何使用普通函数则会出现错误,原因如下:
this指向错误,因为函数调用的上下文并非是group
不能对箭头函数进行 new 操作 不具有 this 自然也就意味着另一个限制:箭头函数不能用作构造器(constructor)。不能用 new 调用它们。
—《现代JavaScript教程》
箭头函数没有 “arguments”
当我们需要使用当前的 this 和 arguments 转发一个调用时,这对装饰器(decorators)来说 非常有用
function defer(f,ms) {
    return function () {
        setTimeout(()=>f.apply(this,arguments),ms);
    }
}
function sayHi(who) {
    console.log(`Hello ${who}`);
}
const sayHiDeferred = defer(sayHi,2000);
sayHiDeferred('Peng');
如何使用普通函数的话,则需要如下这样:
function defer (f,ms) {
    return function(...args) {
        const ctx = this;
        setTimeout(function() {
            return f.apply(ctx,args);
        },ms);
    }
}
箭头函数总结:
- 没有 this
 - 没有 arguments
 - 不能使用 new 进行调用
 - 它们也没有 super (在下一篇类继承中说明)
 
深入理解JavaScript中的箭头的更多相关文章
- 简单理解ECMAScript2015中的箭头函数新特性
		
箭头函数(Arrow functions),是ECMAScript2015中新加的特性,它的产生,主要有以下两个原因:一是使得函数表达式(匿名函数)有更简洁的语法,二是它拥有词法作用域的this值,也 ...
 - 理解 JavaScript 中的 this
		
前言 理解this是我们要深入理解 JavaScript 中必不可少的一个步骤,同时只有理解了 this,你才能更加清晰地写出与自己预期一致的 JavaScript 代码. 本文是这系列的第三篇,往期 ...
 - 全面理解JavaScript中的 this
		
全面理解JavaScript中的 this 上下文 VS 作用域 作用域(scope) 是在运行时代码中的某些特定部分中变量,函数和对象的可访问性.换句话 说,作用域决定了代码区块中变量和其他资源的可 ...
 - 理解JavaScript中的原型继承(2)
		
两年前在我学习JavaScript的时候我就写过两篇关于原型继承的博客: 理解JavaScript中原型继承 JavaScript中的原型继承 这两篇博客讲的都是原型的使用,其中一篇还有我学习时的错误 ...
 - 深入理解JavaScript中创建对象模式的演变(原型)
		
深入理解JavaScript中创建对象模式的演变(原型) 创建对象的模式多种多样,但是各种模式又有怎样的利弊呢?有没有一种最为完美的模式呢?下面我将就以下几个方面来分析创建对象的几种模式: Objec ...
 - 深入理解JavaScript中的属性和特性
		
深入理解JavaScript中的属性和特性 JavaScript中属性和特性是完全不同的两个概念,这里我将根据自己所学,来深入理解JavaScript中的属性和特性. 主要内容如下: 理解JavaSc ...
 - 深入理解javascript中执行环境(作用域)与作用域链
		
深入理解javascript中执行环境(作用域)与作用域链 相信很多初学者对与javascript中的执行环境与作用域链不能很好的理解,这里,我会按照自己的理解同大家一起分享. 一般情况下,我们把执行 ...
 - 【干货理解】理解javascript中实现MVC的原理
		
理解javascript中的MVC MVC模式是软件工程中一种软件架构模式,一般把软件模式分为三部分,模型(Model)+视图(View)+控制器(Controller); 模型:模型用于封装与应用程 ...
 - 理解javascript中的策略模式
		
理解javascript中的策略模式 策略模式的定义是:定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换. 使用策略模式的优点如下: 优点:1. 策略模式利用组合,委托等技术和思想,有效 ...
 
随机推荐
- Mybatis解决字段与属性不匹配的问题、链表查询、嵌套查询、#{}和${}的区别
			
1.使用接口结合xml映射文件 创建一个接口,该接口要和映射文件匹配(接口中方法名要和映射文件中的id相同) 映射文件中命名空间要和接口全类名相同 测试: 创建一个与src同级的源文件夹resourc ...
 - 二本学生拿到腾讯大厂offer的成长记录
			
本人迈莫,是在20年以春招实习生的身份进入鹅厂,经过重重波折,最终成为鹅仔一份子.接下来我会以我亲生经历为例,分享一下普通大学的学生也是可以进去大厂,拭目以待!!! 初入大学 惨遭毒打 时间倒回到17 ...
 - 代码 or 指令,浅析ARM架构下的函数的调用过程
			
摘要:linux程序运行的状态以及如何推导调用栈. 1.背景知识 1.ARM64寄存器介绍: 2.STP指令详解(ARMV8手册): 我们先看一下指令格式(64bit),以及指令对于寄存机执行结果的影 ...
 - ORM框架对比以及Mybatis配置文件详解
			
ORM框架对比以及Mybatis配置文件详解 0.数据库操作框架的历程 (1) JDBC  JDBC(Java Data Base Connection,java数据库连接)是一种用于执行SQL语句 ...
 - MonkeyScript
			
MonkeyScript的简单使用 一. 什么是MonkeyScript MS 是官方提供的,除了像猴子一样随机乱点之外,还可以通过编写脚本的形式,完成一系列固定的操作.MS 提供一整套完善的 API ...
 - 小麦苗数据库巡检脚本,支持Oracle、MySQL、SQL Server和PG等数据库
			
目录 一.巡检脚本简介 二.巡检脚本特点 三.巡检结果展示 1.Oracle数据库 2.MySQL数据库 3.SQL Server数据库 4.PG数据库 5.OS信息 四.脚本运行方式 1.Oracl ...
 - loj10007线段
			
题目描述 数轴上有 n 条线段,选取其中 k 条线段使得这 k 条线段两两没有重合部分,问 k 最大为多少. 输入格式 第一行为一个正整数 n: 在接下来的 n 行中,每行有 2 个数 a_i,b_i ...
 - 济南学习D1T1_haha
			
[问题描述] 栈是一种强大的数据结构,它的一种特殊功能是对数组进行排序.例如,借助一个栈,依次将数组1,3,2按顺序入栈或出栈,可对其从大到小排序: 1入栈:3入栈:3出栈:2入栈:2出栈:1出栈. ...
 - Zabbix系列优秀博文
			
Zabbix系列优秀博文 CSDN:菲宇:Zabbix专栏
 - 使用ganglia 实现监控 hadoop 和 hbase(详细过程总结)
			
一,环境准备 hadoop 2.8.2 分布式环境(三个节点 安装请参考 hadoop分布式环境安装) hbase 1.2.6 分布式环境(三个节点 ,安装参考hbase分布式环境安装 ) 主节点采 ...