JS中不应该使用箭头函数的四种情况详解

 更新时间:2022年07月28日 14:13:21   作者:web前端开发  
箭头函数给我们的工作带来了极大的方便,但是它们有什么缺点呢?我们应该一直使用箭头函数吗?我们应该在哪些场景中停止使用箭头函数?本文就来为大家详细讲讲

箭头函数给我们的工作带来了极大的方便,但是它们有什么缺点呢?我们应该一直使用箭头函数吗?我们应该在哪些场景中停止使用箭头函数?

现在,我们开始吧。

箭头函数的一些缺点

1、不支持参数对象

在箭头函数中,我们不能像在普通函数中那样使用 arguments 对象。

const fn1 = () => {
 console.log('arguments', arguments)
}
fn1('fatfish', 'medium')
function fn2(){
 console.log('arguments', arguments)
}
fn2('fatfish', 'medium')

可以看到,fn1箭头函数报错,但是fn2可以正常读取arguments对象。

我们如何才能在箭头函数中获取所有传递给函数的参数?

是的,没错,你可以使用Spread Operator来解决它。

const fn3 = (...values) => {
 console.log('values', values)
}
fn3('fatfish', 'medium')

2、无法通过apply、call、bind来改变this指针

我相信你可以很容易地知道下面的代码会输出什么。

const fn1 = () => {
 console.log('this-fn1', this)
}
fn1()
function fn2(){
 console.log('this-fn2', this)
}
fn2()

{
 name: 'fatfish'
}

我们希望 fn1 和 fn2 都打印对象,我们应该怎么做?

代码:

const thisObj = {
 name: 'fatfish'
}
const fn1 = () => {
 console.log('this-fn1', this)
}
fn1.call(thisObj)
function fn2(){
 console.log('this-fn2', this)
}
fn2.call(thisObj)

因为箭头函数在定义的时候就决定了它的this指向谁,所以没有办法用fn1.call(thisObj)再次改变它。

什么时候不能使用箭头功能

箭头函数不是万能的,至少有 4 种情况我们不应该使用它们。

1、请不要在构造函数中使用箭头函数

function Person (name, age) {
 this.name = name
 this.age = age
}
const Person2 = (name, sex) => {
 this.name = name
 this.sex = sex
}
console.log('Person', new Person('fatfish', 100))
console.log('Person2', new Person2('fatfish', 100))

为什么 new Person2 会抛出错误

因为构造函数通过 new 关键字生成一个对象实例。生成对象实例的过程也是通过构造函数将this绑定到实例的过程。

但是箭头函数没有自己的this,所以不能作为构造函数使用,也不能通过new操作符调用。

2、请不要在点击事件中操作this

我们经常在 click 事件中通过 this 读取元素本身。

const $body = document.body
$body.addEventListener('click', function () {
 // this and $body elements are equivalent
 this.innerHTML = 'fatfish'
})

但是如果你使用箭头函数给 DOM 元素添加回调,这将等同于全局对象窗口。

const $body = document.body
$body.addEventListener('click', () => {
 this.innerHTML = 'fatfish'
})

3、请不要在对象的方法中使用箭头函数。

const obj = {
 name: 'fatfish',
 getName () {
   return this.name
 },
 getName2: () => {
   return this.name
 }
}
console.log('getName', obj.getName())
console.log('getName2', obj.getName2())

你知道这段代码会输出什么吗?

是的,getName2方法不会打印“fatfish”,因为此时this和window是等价的,不等于obj。

4、请不要在原型链中使用箭头函数

const Person = function (name) {
 this.name = name
}
Person.prototype.showName = function () {
 console.log('showName', this, this.name)
}
Person.prototype.showName2 = () => {
 console.log('showName2', this, this.name)
}
const p1 = new Person('fatfish', 100)
p1.showName()
p1.showName2()

到此这篇关于JS中不应该使用箭头函数的四种情况详解的文章就介绍到这了,更多相关JS箭头函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 简单实现js倒计时功能

    简单实现js倒计时功能

    这篇文章主要为大家详细介绍了js倒计时效果的实现代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • 详解JavaScript原始数据类型Symbol

    详解JavaScript原始数据类型Symbol

    以前提到 JavaScript 原始数据类型时,我们知道有Number,String,Null,Boolean,Undefined这几种。ES6 引入了新的基本数据类型Symbol和BigInt。今天我们就来了解下Symbol类型。Symbol类型是为了解决属性名冲突的问题,顺带还具备模拟私有属性的功能。
    2021-05-05
  • js利用appendChild对<li>标签进行排序的实现方法

    js利用appendChild对<li>标签进行排序的实现方法

    下面小编就为大家带来一篇js利用appendChild对<li>标签进行排序的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-10-10
  • 轻松5句话解决JavaScript的作用域

    轻松5句话解决JavaScript的作用域

    作用域(scope)是javascript语言的基石之一,在构建复杂程序时可能是最头痛的东西,所以这里罗列了五句话轻松搞定并且附上了示例。给需要的朋友参考学习。
    2016-07-07
  • JavaScript操作XLSX文件的示例详解

    JavaScript操作XLSX文件的示例详解

    本文将深入探讨如何使用强大的xlsx库来操作Excel文件,本文将涵盖如何在Node.js和浏览器环境中读取Excel文件,创建新的Excel文件等内容,感兴趣的小伙伴可以了解下
    2024-11-11
  • JavaScript中的Map数据结构详解

    JavaScript中的Map数据结构详解

    这篇文章主要为大家介绍了JavaScript的Map数据结构,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • BOM系列第一篇之定时器setTimeout和setInterval

    BOM系列第一篇之定时器setTimeout和setInterval

    这篇文章主要介绍了BOM系列第一篇之定时器setTimeout和setInterval 的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-08-08
  • 简单谈谈JS数组中的indexOf方法

    简单谈谈JS数组中的indexOf方法

    最近在工作中遇到一个小问题,这篇文章代码我会简化成小例子展示给大家。给大家详细的介绍JS数组中的indexOf方法,用心看到最后会有收获哈,有需要的朋友们下面来一起看看吧。
    2016-10-10
  • JS获取浮动(float)元素的style.left值为空的快速解决办法

    JS获取浮动(float)元素的style.left值为空的快速解决办法

    这篇文章主要介绍了JS获取浮动(float)元素的style.left值为空的快速解决办法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Javascrip实现文字跳动特效

    Javascrip实现文字跳动特效

    这篇文章主要介绍了Javascrip实现文字跳动特效的相关资料,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-11-11

最新评论