美文网首页
ES6新特性箭头函数语法、如何正确使用箭头函数 ![

ES6新特性箭头函数语法、如何正确使用箭头函数 ![

作者: 左左front | 来源:发表于2020-10-18 19:29 被阅读0次

ES6新特性箭头函数语法、如何正确使用箭头函数

转载自:https://blog.csdn.net/qq_32614411/article/details/80897256

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是词法作用域,由上下文确定。(词法作用域就是定义在词法阶段的作用域。换句话说,词法作用域是由你在写代码时将变量和块作用域写在哪里来决定的,因此当词法分析器处理代码时会保持作用域不变 。)

非箭头函数

image

现在,箭头函数完全修复了this的指向,this总是指向词法作用域,也就是外层调用者Person

image

由于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()的区别和应用》

image

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

image

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

总结

  1. 类似于匿名函数,在某些情况下使用,可减少代码量
  2. 代码简洁,this提前定义
  3. 代码太过简洁,导致不好阅读
  4. this提前定义,导致无法使用js进行一些在ES5里面看起来非常正常的操作(若使用箭头函数,在监听点击事件的回调函数中,就无法获取到当前点击的元素咯,详见《正确使用箭头函数——什么时候不该用ES6箭头函数》
  5. 总的来说,箭头函数只是一种函数的简写,有其利弊,可用可不用,看大家心情,当然也得用的正确

相关文章

  • ES6新特性箭头函数语法、如何正确使用箭头函数 ![

    ES6新特性箭头函数语法、如何正确使用箭头函数 转载自:https://blog.csdn.net/qq_3261...

  • JavaScript箭头函数

    ES6新语法箭头函数 箭头函数是ES6新语法,因为语法简单、可读性好,所以使用的也很多。箭头函数也是匿名函数,区别...

  • es6、js、css、jquery、vue以及程序设计 知识点总

    es6 列举常用的es6特性。 箭头函数this的指向。 eg:箭头函数的特性 箭头函数内部没有construc...

  • 解析ES6箭头函数中的this

    ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取this的特性,接下来通过本文给大家分享ES6箭头函数...

  • 【ES6】箭头函数用法与深入理解

    语法 ES6 允许使用“箭头”(=>)定义函数,可以简单的认为箭头的左边是函数的参数,箭头的右边是函数的声明(函数...

  • 箭头函数

    一、基本语法 1.定义函数 定义箭头函在数语法上要比普通函数简洁得多,ES6中允许使用箭头 => 来定义箭头函数,...

  • ES6-箭头函数

    ES6允许使用箭头(=>)定义函数,箭头函数的语法多变,根据实际的使用场景有多种形式,但需要由函数参数、箭头和函数...

  • ES6中的箭头函数

    基本语法 ES6 允许使用“箭头”(=>)定义函数。 上面的箭头函数相当于: 如果箭头函数不需要参数或需要多个参数...

  • 箭头函数

    1.箭头函数 基本语法:ES6允许使用“箭头”(=>)定义函数 如果箭头函数不需要参数或需要多个参数,就使用一个圆...

  • ES6箭头函数(Arrow Functions)

    箭头函数是什么?(What) 箭头函数 (Arrow Functions)也称“胖箭头函数”,是ES6全新的特性。...

网友评论

      本文标题:ES6新特性箭头函数语法、如何正确使用箭头函数 ![

      本文链接:https://www.haomeiwen.com/subject/tzzapktx.html