es6+-箭头函数细节与应用场景

与函数表达式的区别
箭头函数

  • 更简洁的语法:箭头函数允许你用更简洁的方式书写函数。
  • 没有自己的this、arguments、super和new.target:箭头函数不绑定这些关键字,它们从封闭的词法环境中继承这些值。
  • 不能用作构造函数:由于没有自己的this,箭头函数不能用作构造函数,也就是说,不能使用new操作符。
  • 没有原型:由于不能用作构造函数,箭头函数没有prototype属性。
  • 不能改变this的绑定:call、apply和bind方法不能改变箭头函数的this值。
  • 不适用于方法:由于箭头函数不绑定this,它们不适合作为对象的方法使用。
  • 不支持arguments对象:箭头函数不绑定arguments对象,需要使用剩余参数(...rest)来获取所有传入的参数。
  • 匿名函数:箭头函数通常是匿名的,尽管可以为其指定一个名字。

函数表达式

  • 更传统的语法:函数表达式更接近于传统编程语言中函数的定义方式。
  • 有自己的this、arguments、super和new.target:函数表达式有自己的执行上下文,包括this、arguments等。
  • 可以用作构造函数:函数表达式可以用new操作符来创建对象实例。
  • 有原型:函数表达式有prototype属性,可以用来构建对象的原型链。
  • 可以改变this的绑定:可以使用call、apply和bind方法来改变函数表达式的this值。
  • 适用于方法:函数表达式可以用作对象的方法,并且this会指向调用该方法的对象。
  • 支持arguments对象:函数表达式可以访问arguments对象,它包含了函数接收到的所有参数。
  • 可以具名或匿名:函数表达式可以是具名的,也可以是匿名的。

使用场景

1、临时性使用的函数:

  • 事件处理函数
  • 异步处理函数
  • 匿名函数

2、为了绑定外层this的函数(比如定时器层级的this)

3、在不影响其他代码的情况下,保持代码间接。(比如数组方法中的函数,自行编写的回调函数)

相关推荐
小墨宝1 分钟前
js 生成pdf 并上传文件
前端·javascript·pdf
www_pp_1 小时前
# 构建词汇表:自然语言处理中的关键步骤
前端·javascript·自然语言处理·easyui
YuShiYue1 小时前
pnpm monoreop 打包时 node_modules 内部包 typescript 不能推导出类型报错
javascript·vue.js·typescript·pnpm
天天扭码1 小时前
总所周知,JavaScript中有很多函数定义方式,如何“因地制宜”?(ˉ﹃ˉ)
前端·javascript·面试
一个专注写代码的程序媛1 小时前
为什么vue的key值,不用index?
前端·javascript·vue.js
장숙혜2 小时前
ElementUi的Dropdown下拉菜单的详细介绍及使用
前端·javascript·vue.js
火柴盒zhang2 小时前
websheet之 编辑器
开发语言·前端·javascript·编辑器·spreadsheet·websheet
WKK_2 小时前
uniapp自定义封装tabbar
前端·javascript·小程序·uni-app
莫问alicia2 小时前
react 常用钩子 hooks 总结
前端·javascript·react.js
Mintopia2 小时前
图形学中的数学基础与 JavaScript 实践
前端·javascript·计算机图形学