箭头函数和普通函数的区别

箭头函数和普通函数在以下几个方面存在区别:

语法

  • 普通函数 :使用function关键字定义,有函数名、参数列表和函数体,形式为function functionName(parameters) { functionBody }
  • 箭头函数 :使用箭头=>定义,参数放在箭头左边,函数体放在箭头右边。如果只有一个参数,可以省略参数的括号;如果函数体只有一条语句,可以省略花括号,并且会自动返回该语句的结果。例如param => expression(param1, param2) => { functionBody }

函数上下文(this指向)

  • 普通函数this的指向在函数被调用时确定,取决于函数的调用方式。在全局环境中调用,this指向全局对象(浏览器中是window);作为对象的方法调用时,this指向该对象;使用callapplybind方法调用时,可以显式指定this的指向。
  • 箭头函数 :没有自己独立的this,它的this继承自外层作用域,在定义时就被确定,不会被调用方式改变。

构造函数

  • 普通函数 :可以作为构造函数使用,通过new关键字创建对象实例,函数内部的this会指向新创建的对象,并且可以使用prototype属性来添加原型方法和属性。
  • 箭头函数 :不能作为构造函数使用,不能使用new关键字调用,否则会抛出错误。因为箭头函数没有自己的this,也没有prototype属性。

arguments 对象

  • 普通函数 :在函数内部可以使用arguments对象来获取传递给函数的所有参数,即使没有在函数定义中显式声明参数,也可以通过arguments来访问。
  • 箭头函数 :没有arguments对象,如果需要获取参数,可以使用剩余参数...来代替。

执行上下文

  • 普通函数:会创建自己的执行上下文,包括变量环境、词法环境等,在函数执行时进行一系列的初始化操作。

  • 箭头函数:不会创建自己的执行上下文,而是直接继承外层函数的执行上下文。

一般来说,当需要使用独立的this指向、作为构造函数或者需要访问arguments对象时,应使用普通函数;而在一些回调函数、箭头函数更简洁的场景下,或者需要确保this指向稳定的情况下,箭头函数更为合适。

相关推荐
Amumu121387 分钟前
Vuex介绍
前端·javascript·vue.js
We་ct8 分钟前
LeetCode 54. 螺旋矩阵:两种解法吃透顺时针遍历逻辑
前端·算法·leetcode·矩阵·typescript
2601_9494800642 分钟前
【无标题】
开发语言·前端·javascript
css趣多多1 小时前
Vue过滤器
前端·javascript·vue.js
理人综艺好会1 小时前
Web学习之用户认证
前端·学习
We་ct1 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
weixin_395448912 小时前
main.c_cursor_0129
前端·网络·算法
2401_859049082 小时前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子3 小时前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js
刘一说3 小时前
Vue 动态路由参数丢失问题详解:为什么 `:id` 拿不到值?
前端·javascript·vue.js