【ES6】箭头函数用法与深入理解

语法

ES6 允许使用“箭头”(=>)定义函数,可以简单的认为箭头的左边是函数的参数,箭头的右边是函数的声明(函数体)。

  1. 具有一个参数的简单函数
// 当只有一个参数时,圆括号是可选的:
// (单一参数) => {函数声明}
// 单一参数 => {函数声明}

var f = v => v;

// 等同于
var f = function (v) {
  return v;
};
  1. 如果箭头函数不需要参数或需要多个参数,就使用一个圆括号()代表参数部分,多个参数之间用逗号间隔。
// 没有参数的函数应该写成一对圆括号。
// () => {函数声明}

var f = () => 5;
// 等同于
var f = function () { return 5 };

// (参数1, 参数2, …, 参数N) => { 函数声明 }
// (参数1, 参数2, …, 参数N) => 表达式(单一)
// 相当于:(参数1, 参数2, …, 参数N) =>{ return 表达式; }

var sum = (num1, num2) => num1 + num2;
// 等同于
var sum = function(num1, num2) {
  return num1 + num2;
};

  1. 箭头函数的代码块部分多于一条语句,就要使用大括号{}将它们括起来,并且使用return语句返回。
var add = (a, b) => {
    if (typeof a == 'number' && typeof b == 'number') {
        return a + b
    } else {
        return 0
    }
}
  1. 如果箭头函数直接返回一个对象,必须在对象外面加上括号(),否则会报错。
// 返回对象字面表达式时需给函数体加括号(),否则会报错
// 参数=> ({foo: bar})

// 报错
let getTempItem = id => { id: id, name: "Temp" };

// 不报错
let getTempItem = id => ({ id: id, name: "Temp" });
  1. 箭头函数支持参数列表解构。
let f = ([a, b] = [1, 2], {x: c} = {x: a + b}) => a + b + c;
f();  // 6
  1. 支持rest参数和默认参数。
// (参数1, 参数2, ...rest) => {函数声明}
// (参数1 = 默认值1,参数2, …, 参数N = 默认值N) => {函数声明}

const numbers = (...nums) => nums;
numbers(1, 2, 3, 4, 5)
// [1,2,3,4,5]

let f = (x, y = 1) => x+y;
f(1); // 2

关于rest参数和默认参数,可参考《【ES6】函数默认参数与rest参数

注意点

  1. typeof运算符和普通的function一样。
var f = a => a;
console.log(typeof f); // "function"
  1. Function的实例,instanceof也返回true
var f = a => a;
console.log(f instanceof Function); // true
  1. 箭头函数不会创建自己的this,它只会从自己的作用域链的上一层继承this,而且在箭头函数中,this的指向是固定的,不能改变。
// 在箭头函数中,`this`属于词法作用域,直接由上下文确定。
//ES5普通函数
function Man(){
  this.age=22;
  return function(){
    this.age+1;
  }
}
var cala=new Man();
console.log(cala())//undefined

//ES6箭头函数
function Man(){
  this.age=22;
  return () => this.age+1;
}
var cala=new Man();
console.log(cala())//23

  1. 不存在arguments对象。如果要用,可以用 rest 参数代替。
//没有arguments
var foo = (a,b) => {return arguments[0]*arguments[1]}
console.log(foo(3,5))
//arguments is not defined
  1. 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
//不能使用new 关键字
var Obj = () => {"hello world"};
var o = new Obj(); 
// TypeError: Obj is not a constructor
  1. 箭头函数没有原型。
//没有原型
var Obj = () => {};
console.log(Obj.prototype); 
// undefined
  1. 不可以使用yield命令,因此箭头函数不能用作 Generator 函数。
  2. 箭头函数在参数和箭头之间不能换行
var func = ()
           => 1; 
// SyntaxError: expected expression, got '=>'
  1. 箭头函数具有与常规函数不同的特殊运算符优先级解析规则。
let callback;

callback = callback || function() {}; // ok

callback = callback || () => {};      
// SyntaxError: invalid arrow-function arguments

callback = callback || (() => {});    // ok

参考文章

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,221评论 0 13
  • 前面的话 函数是所有编程语言的重要组成部分,在ES6出现前,JS的函数语法一直没有太大的变化,从而遗留了很多问题,...
    CodeMT阅读 843评论 0 1
  • 很多女孩特别害怕受到伤害,不管是渣男还是绿茶婊,好像在此之前他们都是最好的男票和闺蜜,而瞬间变身,让自己的玻璃心碎...
    药山阅读 1,150评论 0 51
  • 一键上链! 今天在朋友圈看到很多人在 讨论 北大yuexin上链事件. 虽然看到很多人写了教程 如何上链,但是觉得...
    高金01阅读 380评论 0 0
  • 郑州的初雪已经下过了,我还没向他表白。 讲讲我的这段暗恋吧。 如果他没有准备大四考研,也没有一直呆在那一间教室,更...
    七味厘阅读 264评论 0 0