java有箭头函数吗_几种应该避免使用箭头函数的情况

7e7c185e9a3f5738776d5a4179234300.png

几种应该避免使用箭头函数的情况

⭐️ 更多前端技术和知识点,搜索订阅号 JS 菌 订阅

避免在定义对象方法时使用

箭头函数虽然因语法简练受人追捧。但由于没有 this 会导致在一些情况下出现预想不到的意外情况。😯

比如在对象中定义一个方法:

4cb055d45ea6fb634ab378ece9cf742e.png

看起来很完美调用这个方法能够按照预期,获得对象的 food 属性

但如果将其改为箭头函数:

38f94679111c956341c7fe291600a2af.png

由于箭头函数自身没有 this 会导致自动继承外层的 this 导致打印出的变量出错,这个 bug 有点 🍤

因此不要在对象方法中使用箭头函数

避免在 prototype 上使用

因为没有 this 导致 this 指向错误,所以在定义 prototype 方法上一定记得不要使用箭头函数

7102b36f23519994efc4e4d3bba56bb6.png

避免在需要 arguments 上使用

因为箭头函数没有 arguments 因此如果外层是另外一个函数,那么 arguments 是这个外层函数的

e083e4d810c876894fa55a3043a2afaf.png

当然可以使用 rest 操作符获取对应的参数

避免在动态上下文中的回调函数里使用

如果你需要你的上下文是可变的,动态的,那么不要使用箭头函数

比如在一个页面中,我们需要为每一个 p 元素增加一个事件处理函数,那么:

document.querySelectorAll('p').forEach(elem => {

elem.addEventListener('click', () => {

console.log(this.innerText.length) // ❌ 这个时候 this 指向 window,因此会报错

})

})

改为普通函数才可以正确访问到预期的 this:

document.querySelectorAll('p').forEach(elem => {

elem.addEventListener('click', function() {

console.log(this.innerText.length) // ✅ 这个时候 this 指向 elem

})

})

避免在需要 caller 的时候使用

因 caller 早已不再是推荐的标准,应该在任何时候都避免使用 caller 这里就不多说了 🈲️

7bc32290c6fb2750317985202b7fb2c4.png

其他情况下尤其是 map reduce forEach 等并没有什么复杂的逻辑的时候使用箭头函数能够增加阅读体验,想必是极好的 👏

that's all

请关注我的订阅号,不定期推送有关 JS 的技术文章,只谈技术不谈八卦 😊

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java 12 之前的版本中,switch 语句只能使用 return 来结束代码块。从 Java 12 开始,引入了 switch 表达式(Switch Expressions)的概念,允许在 switch 语句中使用箭头 `->` 来执行相应的代码块,而无需使用 return。 具体来说,从 Java 12 开始,可以在以下三种情况使用箭头 `->`: 1. Lambda 表达式中的箭头:这是在 Java 8 中引入的箭头语法,用于定义匿名函数。例如: ```java Function<Integer, String> func = (x) -> x > 0 ? "positive" : "negative"; ``` 2. 方法引用中的箭头:用于引用已有的方法。例如: ```java List<Integer> numbers = Arrays.asList(1, 2, 3, 4, 5); numbers.forEach(System.out::println); ``` 3. Switch 表达式中的箭头:从 Java 12 开始,可以在 switch 语句中使用箭头 `->` 来执行相应的代码块。例如: ```java String result = switch (day) { case "Monday" -> "It's Monday"; case "Tuesday", "Wednesday" -> "It's Tuesday or Wednesday"; default -> "It's another day"; }; ``` 区别在于,当使用箭头 `->` 执行代码块时,它只是一个普通的代码执行路径,并不会导致整个方法或函数的返回。而使用 return 关键字,则会立即结束方法或函数,并返回相应的值。 在 switch 表达式中,箭头 `->` 后面的代码块将被执行,并且该代码块的结果将成为整个 switch 表达式的结果。如果没有匹配的 case,可以使用 `default` 来指定默认的执行代码块。 需要注意的是,在使用箭头 `->` 执行代码块时,代码块必须是表达式,即具有返回值,并且返回值的类型必须与 switch 表达式的类型一致。如果需要执行多个语句或者需要进行复杂的逻辑处理,可以使用大括号 `{}` 来创建代码块。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值