JavaScript 初学者必看“箭头函数”

简介: 译者按: 箭头函数看上去只是语法的变动,其实也影响了this的作用域。 原文: JavaScript: Arrow Functions for Beginners 译者: Fundebug 本文采用意译,版权归原作者所有 本文我们介绍箭头(arrow)函数的优点。

译者按: 箭头函数看上去只是语法的变动,其实也影响了this的作用域。

本文采用意译,版权归原作者所有

本文我们介绍箭头(arrow)函数的优点。

更简洁的语法

我们先来按常规语法定义函数:

function funcName(params) {
    return params + 2;
}
funcName(2);
// 4

该函数使用箭头函数可以使用仅仅一行代码搞定!

var funcName = params => params + 2;
funcName(2);
// 4

是不是很酷!虽然是一个极端简洁的例子,但是很好的表述了箭头函数在写代码时的优势。我们来深入了解箭头函数的语法:

parameters => {
    statements;
};

如果没有参数,那么可以进一步简化:

() => {
    statements;
};

如果只有一个参数,可以省略括号:

parameters => {
    statements;
};

如果返回值仅仅只有一个表达式(expression), 还可以省略大括号:

parameters => expression

// 等价于:
function (parameters){
  return expression;
}

现在你已经学会了箭头函数的语法,我们来实战一下。打开 Chrome 浏览器开发者控制台,输入:

var double = num => num * 2;

我们将变量double绑定到一个箭头函数,该函数有一个参数num, 返回 num * 2。 调用该函数:

double(2);
// 4

double(3);
// 6

一行代码搞定 BUG 监控:Fundebug

没有局部this的绑定

和一般的函数不同,箭头函数不会绑定this。 或者说箭头函数不会改变this本来的绑定。
我们用一个例子来说明:

function Counter() {
    this.num = 0;
}
var a = new Counter();

因为使用了关键字new构造,Counter()函数中的this绑定到一个新的对象,并且赋值给a。通过console.log打印a.num,会输出 0。

console.log(a.num);
// 0

如果我们想每过一秒将a.num的值加 1,该如何实现呢?可以使用setInterval()函数。

function Counter() {
    this.num = 0;
    this.timer = setInterval(function add() {
        this.num++;
        console.log(this.num);
    }, 1000);
}

我们来看一下输出结果:

var b = new Counter();
// NaN
// NaN
// NaN
// ...

你会发现,每隔一秒都会有一个NaN打印出来,而不是累加的数字。到底哪里错了呢?
首先使用如下语句停止setInterval函数的连续执行:

clearInterval(b.timer);

我们来尝试理解为什么出错:根据上一篇博客讲解的规则,首先函数setInterval没有被某个声明的对象调用,也没有使用new关键字,再之没有使用bind, callapplysetInterval只是一个普通的函数。实际上setInterval里面的this绑定到全局对象的。我们可以通过将this打印出来验证这一点:

function Counter() {
    this.num = 0;
    this.timer = setInterval(function add() {
        console.log(this);
    }, 1000);
}
var b = new Counter();

你会发现,整个window对象被打印出来。 使用如下命令停止打印:

clearInterval(b.timer);

回到之前的函数,之所以打印NaN,是因为this.num绑定到window对象的num,而window.num未定义。

那么,我们如何解决这个问题呢?使用箭头函数!使用箭头函数就不会导致this被绑定到全局对象。

function Counter() {
    this.num = 0;
    this.timer = setInterval(() => {
        this.num++;
        console.log(this.num);
    }, 1000);
}
var b = new Counter();
// 1
// 2
// 3
// ...

通过Counter构造函数绑定的this将会被保留。在setInterval函数中,this依然指向我们新创建的b对象。

为了验证刚刚的说法,我们可以将 Counter函数中的this绑定到that, 然后在setInterval中判断thisthat是否相同。

function Counter() {
    var that = this;
    this.timer = setInterval(() => {
        console.log(this === that);
    }, 1000);
}
var b = new Counter();
// true
// true
// ...

正如我们期望的,打印值每次都是true。最后,结束刷屏的打印:

clearInterval(b.timer);

总结

  • 箭头函数写代码拥有更加简洁的语法;
  • 不会绑定this

版权声明

转载时请注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/05/25/arrow-function-for-beginner/

目录
相关文章
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
42 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
2月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
2月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
44 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
JavaScript 前端开发 Java
【javaScript数组,函数】的基础知识点
【javaScript数组,函数】的基础知识点
28 5
|
2月前
|
JavaScript 前端开发
Node.js 函数
10月更文挑战第5天
24 3
|
2月前
|
前端开发 JavaScript
探索JavaScript函数基础
探索JavaScript函数基础
20 3
|
2月前
|
JavaScript 前端开发
js轮播图有左右箭头和小点
js轮播图有左右箭头和小点
35 1
下一篇
DataWorks