zoukankan      html  css  js  c++  java
  • JavaScript:学习笔记(5)——箭头函数=>以及实践

    JavaScript:学习笔记(5)——箭头函数=>以及实践

    理论知识

    介绍

      箭头函数表达式的语法比函数表达式更短,并且没有自己的thisargumentssuper或 new.target。这些函数表达式更适用于那些本来需要匿名函数的地方,并且它们不能用作构造函数

      箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有两种格式,一种像下面这样,只包含一个表达式,连{ ... }return都省略掉了

    x => x * x
    
    /*上面的箭头函数相当于*/
    
    function (x) {
        return x * x;
    }

      还有一种可以包含多条语句,这时候就不能省略{ ... }return

    x => {
        if (x > 0) {
            return x * x;
        }
        else {
            return - x * x;
        }
    }

      如果要返回一个对象,就要注意,如果是单表达式,这么写的话会报错:

    // SyntaxError:
    x => { foo: x }

      故返回对象时函数体的{ ... }有语法冲突,所以要改为({....})

    // ok:
    x => ({ foo: x })

      其语法结构可总结如下:

    (参数1, 参数2, …, 参数N) => { 函数声明 }
    (参数1, 参数2, …, 参数N) => 表达式(单一)
    //相当于:(参数1, 参数2, …, 参数N) =>{ return 表达式; }
    
    // 当只有一个参数时,圆括号是可选的:
    (单一参数) => {函数声明}
    单一参数 => {函数声明}
    
    // 没有参数的函数应该写成一对圆括号。
    () => {函数声明}
    //加括号的函数体返回对象字面表达式:
    参数=> ({foo: bar})
    
    //支持剩余参数和默认参数
    (参数1, 参数2, ...rest) => {函数声明}
    (参数1 = 默认值1,参数2, …, 参数N = 默认值N) => {函数声明}
    
    //同样支持参数列表解构
    let f = ([a, b] = [1, 2], {x: c} = {x: a + b}) => a + b + c;
    f();  // 6

    关于this

      和一般的函数不同,箭头函数不会绑定this。 或则说箭头函数不会改变this本来的绑定
      我们用一个例子来说明:

    function Counter() {
      this.num = 0;
    }
    var a = new Counter();  

      因为使用了关键字new构造,Count()函数中的this绑定到一个新的对象,并且赋值给a。通过console.log打印a.num,会输出0。即

    console.log(a.num);
    // 0
    

      如果我们想每过一秒将a.num的值加1,该如何实现呢?可以使用setInterval()函数。

    function Counter() {
      this.num = 0;
      this.timer = setInterval(function add() {
        this.num++;
        console.log(this.num);
      }, 1000);
    }
    

      我们来看一下输出结果:

    var b = new Counter();
    // NaN
    // NaN
    // NaN
    // ...
    

      你会发现,每隔一秒都会有一个NaN打印出来,而不是累加的数字。到底哪里错了呢?首先函数setInterval没有被某个声明的对象调用,也没有使用new关键字,再之没有使用bindcallapplysetInterval只是一个普通的函数。实际上setInterval里面的this绑定到全局对象的。我们可以通过将this打印出来验证这一点:

      回到之前的函数,之所以打印NaN,是因为this.num绑定到window对象的num,而window.num未定义

      那么,我们如何解决这个问题呢?使用箭头函数!使用箭头函数就不会导致this被绑定到全局对象

    function Counter() {
      this.num = 0;
      this.timer = setInterval(() => {
        this.num++;
        console.log(this.num);
      }, 1000);
    }
    var b = new Counter();
    // 1
    // 2
    // 3
    // ...
    

      通过Counter构造函数绑定的this将会被保留。在setInterval函数中,this依然指向我们新创建的b对象

      其实这里也为了一个持续困扰我的问题,即是一种hack写法。 

    var that = this;

    最后总结两点就是

    1. 箭头函数写代码拥有更加简洁的语法
    2. 不会绑定this。 

    参考链接

    • MDN箭头函数:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Functions/Arrow_functions
    • 廖雪峰箭头函数:https://www.liaoxuefeng.com/wiki/.......
    • FunDebug的文章:https://blog.fundebug.com/2017/05/25/arrow-function-for-beginner/
  • 相关阅读:
    数据不是搜集起来的,是沉淀下来的,跟脚印一样,脚印不是修路的人搜集起来的,只要有了路就一定有脚印,不可能说修一条路不留下脚印,世界上没有这样的路
    VC6.0编译的DLL文件能否反编译知道里面的代码?
    Why does the PDB format change every release?
    mysql_query与 mysql_real_query区别
    如何把Backtrack 5安装到U盘/Backtrack 4安装方法
    FreeBSD:像Linux下一样使用vim
    栈的出栈序列个数
    npm outdated -g --depth=0
    npm Updating packages downloaded from the registry
    TypeScript安装
  • 原文地址:https://www.cnblogs.com/MrSaver/p/9893314.html
Copyright © 2011-2022 走看看