《理解 ES6》阅读整理:函数(Functions)(四)Arrow Functions
箭头函数(Arrow Functions)
就像名字所说那样,箭头函数使用箭头(=>)来定义函数。与传统函数相比,箭头函数在多个地方表现不一样。
箭头函数语法(Arrow Function Syntax)
箭头函数有多种实现方法。比如你想实现一个只有一个参数并且直接返回此参数值的函数:
let reflect = value => value;
//相当于下面的函数
let reflect = function(value) {
return value;
};
上面的例子中,函数只有一个参数,所以用不用()都是可以的。如果你的参数包含多个,就需要用()包住参数了:
let sum = (num1, num2) => num1 + num2;
//相当于下面的函数
let sum = function(num1, num2) {
return num1 + num2;
};
另外如果函数没有参数,()也是必须的:
let getName = () => "Zakas";
//相当于下面的函数
let getName = function() {
return "Zakas";
};
如果函数体内包含多个表达式,那么就需要用{}包围住函数体了:
let sum = (num1, num2) => {
num1 = num1 + 3;
return num1 + num2;
};
//相当于下面的函数
let sum = function(num1, num2) {
num1 = num1 + 3;
return num1 + num2;
};
其实可以看到,箭头函数可以直接按照(参数)=> {函数体}的方式来写就可以了。上面的例子只是为了说箭头函数在某些情况下可以简写。
那么除了语法外,箭头函数与传统函数相比,有哪些不一样呢?
1、没有this、super、argument和new.target绑定
this、super、argument和new.target的值由最内层包含箭头函数的非箭头函数决定。首先来看arugments绑定:
function outer(num1, num2) {
return function () {
return arguments[0];
}
}
let inner = outer(1, 2);
console.log(inner(3)); //
----------------------------------------------------------
function outer(num1, num2) {
return () => {
return arguments[0];
}
}
let inner = outer(1, 2);
console.log(inner(3)); //
箭头函数本身没有arguments对象,实际上访问的是外层的outer函数的arguments对象,所以输出1。 不过在箭头函数中可以使用剩余参数访问函数的参数。
在JavaScript中,this绑定是一个比较复杂的机制,因为this具体指向的值要到实际执行时才能决定,并不一定是定义时所指向的值。在箭头函数中没有this绑定,其实就是指this的值在函数定义时就已经确定了,并不会在实际执行时改变值。来看一个例子:
function foo() {
return () => {
return this.a;
}
}
var obj1 = {a: 2};
var obj2 = {a: 3};
var bar = foo.call(obj1);
console.log(bar.call(obj2)); //
上面的代码中,bar在创建时,this被绑定到obj1上,然后在执行时,this的值不会被重新绑定到obj2,因此输出2。如果里面的函数是传统函数,那么输出3。
new.target和super都是ES6引入的标准,在后面会进行说明。
2、没有prototype,不能被new调用
let foo = () => {};
console.log(foo.prototype); // undefined
let obj = new foo(); // TypeError: foo is not a constructor
3、不允许重复命名的参数
不管是strict模式还是not-strict模式,箭头函数都不允许重复命名的参数:
let sum = (num1, num2, num1) => { // SyntaxError: Duplicate parameter name not allowed in this context
num1 = num1 + 3;
return num1 + num2;
};
《理解 ES6》阅读整理:函数(Functions)(四)Arrow Functions的更多相关文章
- 《理解 ES6》阅读整理:函数(Functions)(五)Name Property
名字属性(The name Property) 在JavaScript中识别函数是有挑战性的,因为你可以使用各种方式来定义一个函数.匿名函数表达式的流行使用导致函数调试困难,在栈信息中难以找出函数名. ...
- 《理解 ES6》阅读整理:函数(Functions)(一)Default Parameter Values
对于任何语言来说,函数都是一个重要的组成部分.在ES6以前,从JavaScript被创建以来,函数一直没有大的改动,留下了一堆的问题和很微妙的行为,导致在JavaScript中使用函数时很容易出现错误 ...
- ES6学习笔记<二>arrow functions 箭头函数、template string、destructuring
接着上一篇的说. arrow functions 箭头函数 => 更便捷的函数声明 document.getElementById("click_1").onclick = ...
- JavaScript ES6 Arrow Functions(箭头函数)
1. 介绍 第一眼看到ES6新增加的 arrow function 时,感觉非常像 lambda 表达式. 那么arrow function是干什么的呢?可以看作为匿名函数的简写方式. 如: var ...
- 深入浅出ES6(七):箭头函数 Arrow Functions
作者 Jason Orendorff github主页 https://github.com/jorendorff 箭头符号在JavaScript诞生时就已经存在,当初第一个JavaScript教 ...
- ES6 箭头函数(Arrow Functions)
ES6 箭头函数(Arrow Functions) ES6 可以使用 "箭头"(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器). 一.语法 具有一个参数的简单函 ...
- JS ES6中的箭头函数(Arrow Functions)使用
转载这篇ES6的箭头函数方便自己查阅. ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器). 一.语法 基础语法 (参数1, 参数2, …, 参数N) => ...
- 箭头函数 Arrow Functions/////////////////////zzz
箭头符号在JavaScript诞生时就已经存在,当初第一个JavaScript教程曾建议在HTML注释内包裹行内脚本,这样可以避免不支持JS的浏览器误将JS代码显示为文本.你会写这样的代码: < ...
- ES6学习笔记(十四)Generator函数
清明时节雨纷纷,路上行人欲断魂. 借问酒家何处有,牧童遥指杏花村. 二零一九年农历三月初一,清明节. 1.简介 1.1.基本概念 Generator 函数也是 ES6 提供的一种异步编程解决方案,据说 ...
随机推荐
- [题解]USACO 1.3 Wormholes
Wormholes Farmer John's hobby of conducting high-energy physics experiments on weekends has backfire ...
- EXCEL拼接SQL
=CONCATENATE("insert into 表名 (字段名1,字段名2)values (3, '"&C3&"');") 用CONCAT ...
- kafka java实例
生产者 package com; import java.util.Properties; import java.util.concurrent.TimeUnit; import kafka.jav ...
- C# 对Access数据库操作的通用类
(转载自博主Jerry很简单) //Access数据库-C# 操作类 代码using System;using System.Collections.Generic;using System.Linq ...
- ubuntu locale 语言设置
第一步,编辑文件 代码: sudo gedit /var/lib/locales/supported.d/local 写入相关内容,比如写入如下内容: 代码: zh_CN.UTF-8 UTF-8zh ...
- 安装pillow错误的解决方案
错误信息: ValueError: jpeg is required unless explicitly disabled using --disable-jpeg, aborting ...
- 我所理解的SoC
前阵子出去找工作,有的人不太理解,你们SoC有什么可做的,不就是找几个IP来搭积木嘛.你那个FPGA prototyping有什么可做的,不就是编一个镜像嘛. 正好,新项目,重新开始做一颗SoC.接下 ...
- SQL Server已提交读快照隔离级别的设置
如果要把SQL Server数据库事务隔离级别设置为已提交读快照隔离 如果直接运行下面的语句: ALTER Database [mydbname] SET READ_COMMITTED_SNAPSHO ...
- @helper函数使用方法
这个函数方法,我也是通过别人博客看到的,感觉不错和大家一起学习分享一下. 1.自定义函数方法,只在同一个view视图文件里调用 Controller public ActionResult Index ...
- 什麼是 mvc
非常多的Web框架都實踐一個叫做MVC的軟體架構設計模式,將軟體分成三個部分: Model物件包裝了資料與商業邏輯,例如操作資料庫 View表示使用者介面,顯示及編輯表單,可內嵌Ruby程式的HTML ...