• 技术文章 >web前端 >js教程

    es6箭头什么意思

    青灯夜游青灯夜游2021-09-10 15:04:12原创450

    在es6中,箭头“=>”指的是箭头函数,是一种函数的简写方法,它将原函数的“function”关键字和函数名都删掉,并使用“=>”连接参数列表和函数体;例语句“v=>v;”,就相当于“function (v){return v;}”。

    本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

    ES6标准新增了一种新的函数:Arrow Function(箭头函数)。

    基础语法

    通常函数的定义方法

    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总是指向词法作用域,也就是外层调用者Person

    由于this在箭头函数中已经按照词法作用域绑定了,所以,用call()或者apply()调用箭头函数时,无法对this进行绑定,即传入的第一个参数被忽略

    JavaScript中的每一个Function对象都有一个apply()方法和一个call()方法

    apply调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.apply(A, arguments);即A对象调用B对象的方法。func.apply(thisArg, [argsArray])
    call调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.call(A, args1,args2);即A对象调用B对象的方法。func.call(thisArg, arg1, arg2, ...)

    详见《JavaScript中apply()和call()的区别和应用》

    非箭头函数,调用call()时打印的数据

    使用箭头函数之后,不再需要以前hack的写法,var that = this。但不能盲目的使用ES6箭头函数,请看下一节《正确使用箭头函数——什么时候不该用ES6箭头函数》。

    总结

    【推荐学习:javascript高级教程

    以上就是es6箭头什么意思的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:JavaScript es6 箭头函数
    上一篇:es6数组方法有什么 下一篇:javascript怎么增加class
    线上培训班

    相关文章推荐

    • 10个实用的ES6方法,快来收藏!• 深入浅析ES6中的Proxy(代理)• 了解ES6扩展运算符,谈谈它的8种使用方法• 15个值得收藏的实用JavaScript代码片段(项目必备)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网