ES6基础:箭头函数

ES6基础:箭头函数ES6基础系列(三)箭头函数简要分析一个为什么会有箭头函数,它的意义是什么?

大家好,又见面了,我是你们的朋友全栈君。

ES6基础系列(三)箭头函数

一、基本用法

先来看看 ES5 中我们怎么写一个函数

const foo = function (num) { 
   
  return num + 1;
};

再来看看 ES6 为我们提供的箭头函数

const foo = (num) => num + 1;

看这个例子难道箭头函数是为了让我们的代码看上去更“高大上”吗?

我认为是这样的~,但这只是其中的一个很小原因,先来看看它有多“高大上”,也就是常见的用法

多参数

let foo = (value, num) => value * num;

多参数+多条语句:

let foo = (value, num) => { 
   
  const newVal = value * 2;
  return newVal * num;
};

返回一个对象

let foo = (value, num) => ({ 
    total: value * num });

参数是一个对象

let foo = ({ 
    value, num }) => ({ 
    total: value * num });

简化回调函数

const data = [
  { 
    name: "yg1", age: 1 },
  { 
    name: "yg2", age: 2 },
  { 
    name: "yg3", age: 3 },
  { 
    name: "yg4", age: 4 },
];
const res = data.map(({ 
    name, age }) => ({ 
    name, age: age + 1 }));

二、区别

抛开优雅的代码,我们仍要知道箭头函数和普通函数的区别在哪里

2.1 没有 this

箭头函数没有 this,所以需要通过查找作用域链来确定 this 的值。

箭头函数中的 this,就绑定在它最近一层非箭头函数的 this.

一句话理解:箭头函数内部的 this 是词法作用域,由上下文确定。

我们来看这样一段代码:

const obj = { 
   
  name: "111",
  foo: function () { 
   
    console.log(this.name);
    const b = function () { 
   
      console.log(this.name);
    };
    b();
  },
};

obj.foo();
  • 第一个函数字面量在作为对象的方法被调用时。this 指向对象
  • 第二个函数正常调用时指向全局对象——window

同样的代码结构,我们来看一下改造后的代码:

const obj = { 
   
  name: "111",
  foo: function () { 
   
    console.log(this.name);
    const b = () => { 
   
      console.log(this.name);
    };
    b();
  },
};

obj.foo();
  • 第一个函数字面量在作为对象的方法被调用时。this 指向对象
  • 第二个箭头函数,它的 this 绑定在最近一层非箭头函数,也就是 obj 上

2.2 没有 arguments

箭头函数没有自己的 arguments 对象,这不一定是件坏事,因为箭头函数可以访问外围函数的 arguments 对象:

function constant() { 
   
  return () => arguments[0];
}

var result = constant(1);
console.log(result()); // 1

那如果我们就是要访问箭头函数的参数呢?

你可以通过命名参数或者 rest 参数的形式访问参数:

let nums = (...nums) => nums;

2.3 不能通过 new 关键字调用

JavaScript 函数有两个内部方法:[[Call]][[Construct]]

当通过 new 调用函数时,执行 [[Construct]] 方法,创建一个实例对象,然后再执行函数体,将 this 绑定到实例上。

当直接调用的时候,执行 [[Call]] 方法,直接执行函数体。

箭头函数并没有 [[Construct]] 方法,不能被用作构造函数,如果通过 new 的方式调用,会报错。

大致了解了箭头函数以后,我们来看下面的例子:

function foo() { 
   
  return () => { 
   
    return () => { 
   
      return () => { 
   
        console.log("id:", this.id);
      };
    };
  };
}

上面代码之中,只有一个this,就是函数foo的this。

参考

写在最后

JavaScript 系列:

  1. 《JavaScript 内功进阶系列》(已完结)
  2. 《JavaScript 专项系列》(持续更新)
  3. 《ES6 基础系列》(持续更新)

关于我

  • 花名:余光(沉迷 JS,虚心学习中)
  • WX:j565017805

其他沉淀

如果您看到了最后,对文章有任何建议,都可以在评论区留言

这是文章所在 GitHub 仓库的传送门,如果真的对您有所帮助,希望可以点个 star,这是对我最大的鼓励 ~

ES6基础:箭头函数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/148538.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • H5文件读取_如何用电脑读取手机文件

    H5文件读取_如何用电脑读取手机文件H5文件读取:importtorch.utils.dataasdataimporttorchimporth5pyclassDatasetFromHdf5(data.Dataset):def__init__(self,file_path):super(DatasetFromHdf5,self).__init__()hf=h5py.File(file_path)self.data=hf.get(‘data’)

    2022年9月9日
    0
  • 电驴不能下载的办法是什么_电驴是什么

    电驴不能下载的办法是什么_电驴是什么原检索地址:http://www.verycd.com/topics/2897692/点开显示“该内容尚未提供权利证明,无法提供下载”添加后地址:http://www.verycd.gdajie.com/topics/2897692/点开看效果,神奇吧!  即:把前面部分改成:http://www.verycd.gdajie.com

    2022年8月10日
    3
  • puppeteer爬虫教程_python爬虫入门最好书籍

    puppeteer爬虫教程_python爬虫入门最好书籍译者按: 本文通过简单的例子介绍如何使用Puppeteer来爬取网页数据,特别是用谷歌开发者工具获取元素选择器值得学习。原文: AGuidetoAutomating&am

    2022年8月2日
    4
  • MySql必知必会实战练习(四)主键、外键、sql约束、联结表

    本博将对主键、外键、MySql数据库约束和联结表的相关特性进行总结和实战1.主键表中的每一行都应该具有可以唯一标识自己的一列(或一组列),而这个承担标识作用的列称为主键如果没有主键,数据的管理

    2021年12月29日
    42
  • Scala之隐式转换「建议收藏」

    Scala之隐式转换「建议收藏」概述简单说,隐式转换就是:当Scala编译器进行类型匹配时,如果找不到合适的候选,那么隐式转化提供了另外一种途径来告诉编译器如何将当前的类型转换成预期类型。隐式转换有四种常见的使用场景:将某一类型转换成预期类型类型增强与扩展模拟新的语法类型类语法隐式转换有新旧两种定义方法,旧的定义方法指是的“implictdef”形式,这是Scala2.10版本之前的写法,在Scala2.10版本之

    2022年10月11日
    0
  • python构建配对t检验(Paired Student’s t-test)

    python构建配对t检验(Paired Student’s t-test)python构建配对t检验(PairedStudent’st-test)配对样本t检验是单样本t检验的特例。配对t检验有多种情况:配对的两个受试对象分别接受两种不同的处理;同一受试对象接受两种不同的处理;同一受试对象处理前后的结果进行比较(即自身配对);同一对象的两个部位给予不同的处理。配对样本t检验用于检验两个相关的样本是否来自具有相同均值的正态总体。实质是检验两相关样本之差的均值和零之间的差异大小。适用情况有:为了比较两种方法(或两种产品、两种仪器等)的差异,因此令两..

    2022年6月19日
    98

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号