您现在的位置是:亿华云 > 热点
四种不应该使用箭头函数的情况
亿华云2025-10-06 18:42:26【热点】9人已围观
简介箭头函数给我们的工作带来了极大的方便,但是它们有什么缺点呢?我们应该一直使用箭头函数吗?我们应该在哪些场景中停止使用箭头函数?现在,我们开始吧。箭头函数的一些缺点1、不支持参数对象在箭头函数中,我们不
箭头函数给我们的应该工作带来了极大的方便,但是使用它们有什么缺点呢?我们应该一直使用箭头函数吗?我们应该在哪些场景中停止使用箭头函数?
现在,我们开始吧。函数
箭头函数的应该一些缺点
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()写在最后以上这4种情况中,不建议使用箭头函数,如果你还了解其他的情况的话,也请你在留言区给我留言,我们一起学习进步;如果你觉得我今天的内容对你有帮助的话,请记得点赞我,关注我,并将它分享给你身边的朋友,也许能够帮助到他。
最后,感谢你的阅读,祝编程愉快!
很赞哦!(6)
相关文章
- 3、不明先知,根据相关征兆预测可能发生的事件,以便提前做好准备,赶紧注册相关域名。;不差钱域名;buchaqian抢先注册,就是这种敏感类型。预言是最敏感的状态。其次,你应该有眼力。所谓眼力,就是善于从社会上时不时出现的各种热点事件中获取与事件相关的域名资源。眼力的前提是对域名领域的熟悉和丰富的知识。
- 淘宝和网易云怎样知道你喜欢什么?终于有人把推荐系统讲明白了
- 一文教你区分Visual C++、Dev C++、codelite、code::blocks
- 基础篇:Java.Security框架之签名、加密、摘要及证书
- 顶级域名可以增加企业品牌的价值。随着经济的快速发展,域名已不再是企业在网络中的独立地位。顶级域名的服务范围、企业产品、综合形象体现等,对于企业单位来说,顶级域名的重要性不言而喻。
- 高级Python技术:如何在Python应用程序中实现缓存
- 年度喜爱的8个CSS框架
- Spring的Registrar倒排思想送给你
- 2、定期提交和投标域名注册。例如,益华网络点击“立即预订”后,平台会抢先为客户注册域名。当然,一个域名可能会被多个客户预订,所以出价最高的人中标。
- 面了十几家,每次都变着花样问的CyclicBarrier详解