ES6 Arrow 箭头函数

收藏270

阅读2248

更新时间2025-08-20

箭头函数

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

之前:

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

使用箭头函数:

hello = () => {
  return "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!";

开始练习


相关

视频

RELATED VIDEOS

更多

免费

Web前端开发极速入门
初级 Web前端开发极速入门

219920次学习

收藏

免费

前端入门_HTML5
初级 前端入门_HTML5

616946次学习

收藏

免费

30分钟学会网站布局
初级 30分钟学会网站布局

238440次学习

收藏

免费

CSS视频教程-玉女心经版
初级 CSS视频教程-玉女心经版

393054次学习

收藏

免费

独孤九贱(1)_HTML5视频教程

免费

独孤九贱(6)_jQuery视频教程

免费

独孤九贱(7)_Bootstrap视频教程

免费

独孤九贱(2)_CSS视频教程
初级 独孤九贱(2)_CSS视频教程

229605次学习

收藏

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

61.8万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.4万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

71万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.7万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

34万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号