摘要: 箭头函数也有可能会有BUG...

  • 原文:几种应该避免使用箭头函数的情况
  • 作者:JS菌

Fundebug经授权转载,版权归原作者所有。

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

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

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

this

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

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

= 

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

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

2. 避免在 prototype 上使用

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

this

3. 避免在需要 arguments 上使用

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

function 

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

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

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

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

document

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

document

5. 避免在需要 caller 的时候使用

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

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

关于Fundebug

Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java线上应用实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了10亿+错误事件,付费客户有Google、360、金山软件、百姓网等众多品牌企业。欢迎大家免费试用!

箭头函数可被打印却不能调用_5种应该避免使用箭头函数的情况相关推荐

  1. c语言函数参数类型格式化,格式化输出的几种方法 主要介绍format函数的用法

    1 str自带函数格式化输出 rjust() ljust() center() zfill() zfill是补齐零 介绍: rjust(...) S.rjust(width[, fillchar]) ...

  2. python一行输出多个数据_如何在Python中让两个print()函数的输出打印在一行内?

    1.两个连续的print()函数为什么在输出时内容会分行显示? 解:print()中有两个默认参数sep和end,其中sep是代替分隔符,end是代替末尾的换行符,默认使用','代替空格,且默认末尾加 ...

  3. android 调用js怎么获取返回值_js 函数

    函数是一个特殊的对象 具名函数 function 函数名(形式参数1,形式参数2){ 语句 return 返回值 } 匿名函数 上门的具名函数,去掉函数名就是匿名函数 let a =function( ...

  4. 【Android 安装包优化】使用 lib7zr.so 动态库处理压缩文件 ( jni 中 main 函数声明 | 命令行处理 | jni 调用 lib7zr.so 函数库处理压缩文件完整代码 )

    文章目录 一.JNI 中 main 函数声明 二.命令字符串切割并传入 main 函数 三.完整代码示例 1.完整 jni 代码 2.完整 java 代码 3.执行结果 四.参考资料 前置博客 : [ ...

  5. python重复执行函数_Python threading 单线程 timer重复调用函数

    项目中需要使用定时器,每次都使用构造器函数调用: timer = threading.Timer(timerFlag, upload_position) timer.start() 打印线程后发现,每 ...

  6. python中函数的调用_慢步python,编程中函数的概念,python中函数的声明和调用

    函数,曾经是一个很高大尚的概念.笔者是在高中数学里认识的函数,先是从y=2x+3 这条代数式开始的.y是因变量,x是自变量,y因为x取值的变化而变化. 再后来式子变成这样:f(x)=2x+3,f(x) ...

  7. vc中调用其他应用程序的方法(函数) winexec,shellexecute ,createprocess

    三个SDK函数: WinExec,ShellExecute ,CreateProcess可以实现调用其他程序的要求,其中以WinExec最为简单,ShellExecute比WinExec灵活一些,Cr ...

  8. python函数调用自身后果_python 写函数在一定条件下需要调用自身时的写法说明...

    例如以下这个函数:state = 1 def set_state(state): while state: set = int(input('请输入9或5,显示"hello world&qu ...

  9. 变量是否在数组内c语言,函数内创建的数组在调用后,是否就不存在

    函数内创建的数组在调用后,是不是就不存在 本帖最后由 test_lockxxx 于 2014-04-23 09:31:06 编辑 第1种写法: char *getABC() { char str[10 ...

最新文章

  1. 这一年,宇宙“面目”愈发清晰
  2. 【C 语言】一级指针 易犯错误 模型 ( 判定指针合法性 | 数组越界 | 不断修改指针变量值 | 函数中将栈内存数组返回 | 函数间接赋值形参操作 | 指针取值与自增操作 )
  3. android http通过post请求发送一个xml
  4. WORD中如何自动生成目录?
  5. 36岁程序员感慨:天天加班压力太大,有200万存款能转行了吗?
  6. linux 下的csp 模块,linux kernel 中MIGRATE_TYPES的理解
  7. linux timerfd系列函数总结:timerfd.h
  8. elk日志系统中elasticsearch 索引read only 解决
  9. Android AsyncTask源代码浅析
  10. IDEA中Debug的使用
  11. 6月中国最美的地方!对的时间就要去对的地方!
  12. iOS之AR开发--demo制作篇:图片识别
  13. SecureCRT 水平显示不全解决办法
  14. MIG连载-----写模块(3)
  15. Redis运行环境搭建
  16. 为什么用链路聚合_链路聚合技术作用和优点
  17. FPM(FastCGI Process Manager)
  18. 上海:IPTV进入三屏融合时代
  19. oracle建用户之前是否必须建表空间,Oracle数据库-建库、建表空间,建用户
  20. linux怎么卸载fastdfs,FastDFS5.10卸载,centos卸载FastDFS(二)

热门文章

  1. 编写TA链接静态库的方法
  2. Notepad++ 查找匹配中文
  3. (34)内核编程基础
  4. 【递推】P1028 数的计算
  5. DMB DSB ISB 简介
  6. 11、MySQL常见错误代码一览表
  7. 1.5 Double类
  8. JMeter初探三-代理录制
  9. Spring boot统一日志记录
  10. CSS控制鼠标的箭头