React ES6 箭头函数

箭头函数

箭头函数允许我们编写更短的函数语法:

之前:

hello = function() {
  return "Hello World!";
}

亲自试一试 »

使用箭头函数:

hello = () => {
  return "Hello World!";
}

亲自试一试 »

它变短了! 如果函数只有一个语句,并且语句返回一个值,可以去掉括号return关键字:

箭头函数默认返回值:

hello = () => "Hello World!";

亲自试一试 »

注意:仅当函数只有一个语句时才有效。

如果你有参数,你在括号内传递它们:

带参数的箭头函数:

hello = (val) => "Hello " + val;

亲自试一试 »

其实,如果你只有一个参数,你也可以跳过括号:

不带括号的箭头函数:

hello = val => "Hello " + val;
this

亲自试一试 »


关于 this?

this 的处理在箭头函数中也与常规函数不同。

简而言之,箭头函数没有 this 的绑定。

在常规函数中,this 关键字表示调用该函数的对象,可以是窗口、文档、按钮等。

对于箭头函数,this 关键字总是表示定义箭头函数的对象。

让我们看两个例子来理解其中的区别。

这两个示例都调用了两次方法,第一次是在页面加载时,另一次是在用户单击按钮时。

第一个例子使用正则函数,第二个例子使用箭头函数。

结果显示第一个例子返回了两个不同的对象(窗口和按钮),第二个例子返回了两次Header对象。

实例

对于常规函数,this 表示调用该函数的对象:

class Header {
  constructor() {
    this.color = "Red";
  }

//常规功能:
  changeColor = function() {
    document.getElementById("demo").innerHTML += this;
  }
}

const myheader = new Header();

//窗口对象调用函数:
window.addEventListener("load", myheader.changeColor);

//一个按钮对象调用该函数:
document.getElementById("btn").addEventListener("click", myheader.changeColor);

亲自试一试 »

实例

用箭头函数,this代表无论是谁调用函数的Header对象:

class Header {
  constructor() {
    this.color = "Red";
  }

//箭头函数:
  changeColor = () => {
    document.getElementById("demo").innerHTML += this;
  }
}

const myheader = new Header();


//窗口对象调用函数:
window.addEventListener("load", myheader.changeColor);

//一个按钮对象调用函数:
document.getElementById("btn").addEventListener("click", myheader.changeColor);

亲自试一试 »

在使用函数时请记住这些差异。 有时,常规函数的行为是您想要的,如果不是,请使用箭头函数。


学习训练

练习题:

完成这个箭头功能:

hello =  "Hello World!";

开始练习