码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【面试题】ES6语法五之箭头函数


    ES6特性=>。

    1. function foo(x, y){
    2. return x + y
    3. }
    4. var foo = (x, y) => x + y

    包括一个参数列表(零个或多个参数,如果参数不是一个需要小括号包起来),然后是标识=>,函数体放在最后。

    箭头函数是这一部分(x, y) => x + y, 然后这个函数引用被赋给变量foo。

    函数体如果只有一个表达式可以省略{..},并且前面有一个隐含的return。

    箭头函数总是函数表达式,并不存在箭头函数声明,它还是匿名的函数表达式。它们没有用于递归或者事件绑定/解绑定的命名引用。

    箭头函数支持普通函数参数所有功能:默认值,解构,rest参数等。如果这个函数越长, => 带来的好处越小,反之越大。

    this指向 在普通函数中,this指向是动态的,而在箭头函数中,是可以预测的。this在箭头函数中,和词法作用域有关。

    1. var ctrl = {
    2. makeRequest: function(){
    3. var self = this;
    4. btn.addEventListener('click', function (){
    5. self.makeRequest()
    6. }, false)
    7. }
    8. }

    上述代码修改成箭头函数的话,是这样的:

    1. var ctrl = {
    2. makeRequest: function(){
    3. btn.addEventListener('click', ()=>{
    4. this.makeRequest()
    5. }, false)
    6. }
    7. }

    这样,省略了var self = this关键字function。

    但如果全部改为箭头函数的话,this就会乱套。此时指向全局对象。

    1. // 不推荐, 改变了函数原有的本意
    2. var ctrl = {
    3. makeRequest: ()=>{
    4. btn.addEventListener('click', ()=>{
    5. this.makeRequest()
    6. }, false)
    7. }
    8. }

    如果要还原函数原来的意思,我们需要把var self = this这样的hack,或者通过var arg=Array.prototype.slice.call(..)词法复制。这样就达到了安全的全部替换成箭头函数的目的了。

    结语:虽然箭头函数给我带来了便利,但是我们在使用的过程中还是要注意一些隐秘的坑。this的指向问题,是否需要递归?是否需要硬绑定或者是解绑... 判断函数体的长度是否适用箭头函数,可读性如何?

     

       总结给大家推荐一个实用面试题库

     1、前端面试题库 (面试必备)            推荐:★★★★★

    地址:前端面试题库

    2、前端技术导航大全      推荐:★★★★★

    地址:前端技术导航大全

    3、开发者颜色值转换工具   推荐:★★★★★

    地址 :开发者颜色值转换工具

  • 相关阅读:
    SpringMVC的注解、参数传递、页面跳转
    3. 安装lombok & maven镜像设置
    真假难辨!AI人像生成再进化!HyperHuman:基于隐式结构扩散的超逼真人像生成...
    [技术杂谈]几款常用的安装包制作工具
    嵌套快元素垂直外边距的塌陷以及清除网页元素的内外边距
    剖析虚幻渲染体系(14)- 延展篇:现代渲染引擎演变史Part 3(开花期)
    丑单2023秋招笔试第一题 子串之和(C++ 回溯)
    kkFileView源码编译并发布详细教程
    射频模块无线收发RF63U芯片应用数据传输和基建网络
    leetcode18 四数之和 双指针
  • 原文地址:https://blog.csdn.net/weixin_42981560/article/details/126530298
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号