• ES 6 中的箭头函数及用法


    ES6标准新增了一种新的函数:Arrow Function(箭头函数)。
    主要的几种写法如下:

    组成: 参数 => 语句,
    参数不是1个: (参数,参数2)=>语句
    语句不止一条: 参数 =>{语句1;语句2;return 返回值}
    返回的对象格式: 参数=>({对象})
    

    通常函数的定义方法

    var fn1 = function(a, b) {
        return a + b
    }
     
    function fn2(a, b) {
        return a + b
    }
    

    使用ES6箭头函数语法定义函数,将原函数的“function”关键字和函数名都删掉,并使用“=>”连接参数列表和函数体。

    var fn1 = (a, b) => {
        return a + b
    }
     
    (a, b) => {
        return a + b
    }
    

    当函数参数只有一个,括号可以省略;但是没有参数时,括号不可以省略。

    // 无参
    var fn1 = function() {}
    var fn1 = () => {}
     
    // 单个参数
    var fn2 = function(a) {}
    var fn2 = a => {}
     
    // 多个参数
    var fn3 = function(a, b) {}
    var fn3 = (a, b) => {}
     
    // 可变参数
    var fn4 = function(a, b, ...args) {}
    var fn4 = (a, b, ...args) => {}
    

    箭头函数相当于匿名函数,并且简化了函数定义。箭头函数有两种格式,一种只包含一个表达式(函数体中只有一句代码,且代码的执行结果就是返回值,可以省略大括号),省略掉了{ ... }和return。还有一种可以包含多条语句,这时候就不能省略{ ... }和return

    () => return 'hello'
    (a, b) => a + b
    (a) => {
      a = a + 1
      return a
    }
    

    如果返回一个对象,需要特别注意,如果是单表达式要返回自定义对象,不写括号会报错,因为和函数体的{ ... }有语法冲突。注意,用小括号包含大括号则是对象的定义,而非函数主体

    x => {key: x} // 报错
    x => ({key: x}) // 正确
    

    箭头函数中的this 与 普通函数中的 this 指向性问题

    箭头函数中,this指向的固定化,并不是因为箭头函数内部有绑定this的机制,实际原因是箭头函数根本没有自己的this,导致内部的this就是外层代码块的this。正是因为它没有this,所以也就不能用作构造函数。所以在定义对象的时候,定义对象属性,里面的this指向的一般是全局,或者这个对象所在的那个环境中的this。
    一个简单的例子,你就能明白了

    var name = 'window'; 
    
    var A = {
       name: 'A',
       sayHello1: () => {
          console.log(this.name)
       },
       sayHello2(){
          console.log(this.name)
       }
    }
    
    A.sayHello1();// 输出的是 window
    A.sayHello2();// 输出的是 A
    
  • 相关阅读:
    metasploit--multi/samba/usermap_script
    msfcli 不能使用,在新版metasploit不再有效,推荐使用msfconsole
    test.fire渗透测试
    metasploit服务扫描与查点
    Synchronized底层实现
    正在使用的IDEA插件
    JavaWeb
    设计模式
    MySQL
    计算机网络
  • 原文地址:https://www.cnblogs.com/qingheshiguang/p/14789721.html
Copyright © 2020-2023  润新知