返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript箭头函数的五种使用方法及三点注意事项
  • 554
分享到

JavaScript箭头函数的五种使用方法及三点注意事项

JavaScript箭头函数使用方法JavaScript箭头函数注意事项 2022-11-13 14:11:13 554人浏览 独家记忆
摘要

目录使用简略编写结合解构赋值结合扩展运算符this指向的改变绑定this注意细节关于构造关于参数对象关于yield命令面试题前言: 箭头函数是es6新增的定义函数的方式,我们可以使用

前言:

箭头函数是es6新增的定义函数的方式,我们可以使用()=>{}来顶替以前的函数定义方式,下面从五个使用姿势与三点注意事项来刨析箭头函数。

使用

简略编写

当我们箭头函数函数只有一个参数的时候是可以将()省略,当代码块只有一行的时候可以将{}return省略

const fn = num => num.sort();
console.log(fn([2, 1, 3])); // [1,2,3]

如上代码块只有一个参数num且只有一行代码return num.sort(),所以将(){}return省略

结合解构赋值

为了进一步简化还可以与解构赋值结合使用

let person = {
  name: "猪痞恶霸",
  age: 12,
};
const fn = ({ name, age }) => name + "今年" + age + "岁了";
console.log(fn(person)); // 猪痞恶霸今年12岁了

使用解构赋值直接将nameage解构,替换了person,name的用法,使函数更加简洁。

结合扩展运算符

在函数参数定义中可以结合rest参数搭配使用

const fn = (...arr) => arr.sort();
console.log(fn(2, 1, 4)); // [1,2,4]

使用...arr将所有参数都包裹在内,在函数体内进行一些需要的操作。

this指向的改变

在箭头函数中使用this,它的指向是不变的,因为箭头函数没有拥有属于自己的this,其指向的是函数定义时所在的对象 , 所以箭头函数的出现往往就顶替了我们常用的let _that = this又或者在函数结尾使用绑定this指向的对象来解决在函数体内this的问题

var name = "fzf404";
function set() {
  setTimeout(() => {
    console.log(this.name);
  }, 1000);
}
set(); // fzf404
set.call({ name: "猪痞恶霸" }); // 猪痞恶霸

如上例子,在全局中声明了一个name变量,我们再通过call()绑定新的对象{ name: "猪痞恶霸" },在set函数执行的时候,箭头函数被定义,而被定义的时候其已经通过set.call()更改了指向的对象,所以打印出的是新的对象中的name属性,这就是箭头函数的this指向特点,如果是普通函数,其指向依旧是顶层对象。

绑定this

在之前ES5可以通过bindcallapply来显式绑定this对象,而箭头函数的出现打破了这种局面,同时也配套使用::来作为函数绑定的方式

::的使用方法:将要绑定的对象放在::的左边,函数放在::的右边,执行后,函数内的this就会指向绑定的对象

obj::fn
// 等同于
fn.bind(obj)

如上,原来的显式绑定方式与使用::的绑定方式进行一个比较,看过二者的比较就可以了解::的使用了。

注意细节

关于构造

箭头函数无法作为一个构造函数,所以无法通过new命令来构造

const fn = () => {}
let _fn = new fn() // fn is not a constructor

如上,如果使用new来构造的化就会抛出fn不是一个构造函数

关于参数对象

在箭头函数内是无法使用arguments即参数对象,因为在其函数体内部不存在arguments对象当然我们可以使用扩展运算符来代替其使用,比使用参数对象方便。

const fn = () => {
    console.log(arguments)
}
fn() // arguments is not defined

关于yield命令

箭头函数无法使用yield命令,也就是说无法将箭头函数转变为生成器函数,具体是为什么,我的直观感受就是作为生成器必须是function*,而箭头函数的形式无法作为一个生成器。

了解到这里,下面我们来看一道经典的面试题。

面试题

let name = "猪痞恶霸";
let person = {
    name:"fzf404",
    fn: () => {
        setTimeout(() => {
            console.log(this.name);
        })
    }
}
person.fn();

上面是一道考察箭头函数this指向作用域的面试题,它的打印结果为undefined,我们来一点一点分析

  • 使用let在下声明了一个name
  • 再声明一个对象,内含一个name属性和一个方法,该方法使用定时器并打印this.name
  • 调用对象的这个方法,this开始寻找
  • 定时器中的箭头函数没有this,向上寻找,到达person,由于person是一个对象,所以它的{}包裹的不是作用域
  • 继续向上寻找,到达了顶层对象window
  • 查看window内是否含有name属性,由于使用let声明,所以其属性不在window中,打印出undefined

到此这篇关于javascript箭头函数的五种使用方法及三点注意事项的文章就介绍到这了,更多相关js箭头函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: JavaScript箭头函数的五种使用方法及三点注意事项

本文链接: https://lsjlt.com/news/172143.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript箭头函数的五种使用方法及三点注意事项
    目录使用简略编写结合解构赋值结合扩展运算符this指向的改变绑定this注意细节关于构造关于参数对象关于yield命令面试题前言: 箭头函数是ES6新增的定义函数的方式,我们可以使用...
    99+
    2022-11-13
    JavaScript箭头函数使用方法 JavaScript箭头函数注意事项
  • python析构函数用法及注意事项
    主动删除对象调用del 对象;程序运行结束后,python也会自动进行删除其他的对象。 class Animal: def __del__(self): print("销毁对象{0}".f...
    99+
    2022-06-02
    python 析构函数
  • 细数localStorage的用法及使用注意事项
    目录localStorage 介绍localStorage 使用localStorage的浏览器支持情况 localStorage代码中的使用localStorage 注意...
    99+
    2024-04-02
  • Assert.assertEquals的使用方法及注意事项说明
    目录Assert.assertEquals使用及注意事项Assert运行环境需要什么导入什么jar包?使用步骤Assert.assertEquals是什么含义assertEquals...
    99+
    2024-04-02
  • JavaScript数组push方法使用注意事项有哪些
    这篇文章主要介绍了JavaScript数组push方法使用注意事项有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。js 数组的push方...
    99+
    2024-04-02
  • golang函数注释的使用方法和注意事项是什么
    这篇文章主要介绍了golang函数注释的使用方法和注意事项是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇golang函数注释的使用方法和注意事项是什么文章都会有所收获,下面我们一起来看看吧。一、函数注释概...
    99+
    2023-07-05
  • C语言中scanf函数的用法及注意事项
    C语言中scanf函数的用法及注意事项 作为C语言中最常用的输入函数之一,scanf函数在程序开发中具有重要的作用。它能够从标准输入流(键盘)中接收用户输入的数据,并将其存储到指定的变...
    99+
    2024-02-22
    函数 c语言 scanf
  • Assert.assertEquals的使用方法及注意事项是什么
    这篇文章主要介绍了Assert.assertEquals的使用方法及注意事项是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Assert.assertEquals的使用方法及注意事项是什么文章都会有所收获,...
    99+
    2023-06-30
  • Go中函数的使用方法与注意事项是什么
    今天小编给大家分享一下Go中函数的使用方法与注意事项是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。细节汇总函数的形参列...
    99+
    2023-07-04
  • 基于Spring BeanUtils的copyProperties方法使用及注意事项
    如下所示: package com.demo; import lombok.Data; import org.springframework.beans.BeanUtils; i...
    99+
    2024-04-02
  • java volatile关键字使用方法及注意事项
    java volatile关键字使用方法及注意事项什么是volatile关键字volatile 关键字在多线程程序中起着很重要的作用。当多个线程操作同一个变量时,每个线程将拥有对那个变量的本地缓存拷贝,因此,当某一个线程修改了这个变量的值时...
    99+
    2023-05-31
    java volatile ava
  • 数据库inner join语句的使用方法以及注意事项
    这篇文章主要介绍“数据库inner join语句的使用方法以及注意事项”,在日常操作中,相信很多人在数据库inner join语句的使用方法以及注意事项问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2024-04-02
  • JS箭头函数的语法是什么及怎么使用
    本篇内容介绍了“JS箭头函数的语法是什么及怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!JavaScript的箭头函数随着ECMAS...
    99+
    2023-07-04
  • Golang函数的可变函数参数使用注意事项
    Golang是一种强类型、静态编程语言,其函数设计灵活,其中可变函数参数也是常见的实现方式之一,通常会用于函数参数个数不确定或者需要动态参数传递的场景。可变函数参数的使用虽然方便有效,但是也存在一些需要注意的问题,本文将详细介绍一下可变函数...
    99+
    2023-05-17
    Golang 注意事项 可变函数参数
  • React中style的使用方法及注意事项是什么
    这篇“React中style的使用方法及注意事项是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React中style的...
    99+
    2023-07-05
  • localStorage的用法及使用注意事项是什么
    这篇文章主要讲解了“localStorage的用法及使用注意事项是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“localStorage的用法及使用注意事项是什么”吧!localStor...
    99+
    2023-06-29
  • Go语言函数参数传递的方式及注意事项
    Go语言是一种由谷歌开发的开源编程语言,以其性能优异和简洁易读的特点而备受开发者青睐。在Go语言中,函数参数的传递方式对于编写高效、可维护的代码至关重要。本文将探讨Go语言中函数参数传...
    99+
    2024-04-02
  • React forwardRef的使用方法及注意点
    之前使用react.forwardRef始终无法应用于react高阶组件中,最近终于捣鼓出来了,于是记录下来。关键点就是React.forwardRef的API中ref必须指向dom...
    99+
    2024-04-02
  • PHP Laravel 响应函数的使用方法和注意事项有哪些?
    在 Laravel 中,响应函数是非常重要的一种函数。它可以帮助我们将数据返回给用户,并且可以控制返回的数据类型和格式。在本文中,我们将介绍 Laravel 中响应函数的使用方法和注意事项。 一、响应函数的基本使用方法 在 Laravel...
    99+
    2023-08-24
    laravel 响应 函数
  • vue3使用echart的两种引入方式以及注意事项说明
    目录1.直接在组件中引用echarts2.全局引入,一般在app.vue1.先讲vue挂载和echarts渲染2.echarts渲染和数据获取创建好vue3项目后安装echarts ...
    99+
    2022-11-13
    vue3使用echart echart引入方式 vue3 echart引入方式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作