es6箭头函数详解_es6的新特性

es6箭头函数详解_es6的新特性ES6标准新增了一种新的函数:ArrowFunction(箭头函数)。基础语法通常函数的定义方法varfn1=function(a,b){returna+b}functionfn2(a,b){returna+b}使用ES6箭头函数语法定义函数,将原函数的“function”关键字和函数名都删掉,并使用“=>”连接参数…

大家好,又见面了,我是你们的朋友全栈君。

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

非箭头函数

es6箭头函数详解_es6的新特性

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

es6箭头函数详解_es6的新特性

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

es6箭头函数详解_es6的新特性

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

es6箭头函数详解_es6的新特性

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

总结

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

与君共勉:再牛逼的梦想,也抵不住傻逼般的坚持!  

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/125020.html原文链接:https://javaforall.net

(0)
上一篇 2022年4月19日 下午5:40
下一篇 2022年4月19日 下午5:40


相关推荐

  • AMD发布OpenClaw部署方案,助开发者在 PC 上部署端侧 AI 智能体

    AMD发布OpenClaw部署方案,助开发者在 PC 上部署端侧 AI 智能体

    2026年3月14日
    1
  • 无线定位技术概述

    无线定位技术概述FROMhttp labs chinamobile com mblog 82886 阎啸天于蓉蓉武威 中国移动通信有限公司研究院业务所 nbsp 摘 nbsp 要介绍了位置信息和定位性能分析指标等基本概念 根据定位原理与策略的差异对各种定位方法进行分类 概要阐述和比较说明了蜂窝网络 无线局域网络 WLAN 拓扑

    2026年2月19日
    2
  • 腾讯流量主广告点击一次多少钱_好赞移动科技主要做什么的

    腾讯流量主广告点击一次多少钱_好赞移动科技主要做什么的中国的电信市场已经成为全球规模最大的电信市场,11亿左右的客户规模、上万种的业务模式,让国外电信运营商羡慕不已,但与此同时,国内运营商也面临巨大的挑战,特别是随着科技的进步,我们迎来了移动互联网时代,无处不在的网络已经渗透到各个领域。2月27日,工信部正式向中国联通和中国电信颁发LTEFDD牌照,在中国移动凭借TD-LTE牌照抢跑4G网络14个月、4G客户突破1亿大关时,中国市场全面进入4G竞逐

    2025年9月6日
    7
  • 计算机错误代码0X000000be,Win7系统出现蓝屏代码0x000000BE的解决方法「建议收藏」

    计算机错误代码0X000000be,Win7系统出现蓝屏代码0x000000BE的解决方法「建议收藏」蓝屏是我们日常使用电脑的时候经常会碰到的故障,这不就有很多win732位系统用户反映说电脑出现蓝屏错误代码0x000000BE,该怎么解决这样的问题呢,接下来给大家讲解一下Win7系统出现蓝屏代码0x000000BE的解决方法吧。原因分析:0x000000BE错误表示硬件设备的驱动程序试图向只读内存错误地写入数据。这个错误一般是因为硬件设备驱动程序存在BUG或安装不正确引起的。解决方法:按开机按…

    2022年10月8日
    5
  • 初探treap

    初探treaptreap 的基本操作 treap 类似二分查找树 只是加了一个堆 用随机值维护平衡 只是期望平衡 小数据下表现并不是特别优秀 但是足够用了 先水两发 之后再继续搞 poj1338UglyN 把质因子只含 2 3 5 的数叫 UglyNumber 通式为 x 2i 3j 5kx 2 i times3 j times5 k 注意到是一个幂次计算 因此大致地有 0 i j k 3

    2026年3月19日
    3
  • 8 NoSQL数据库有哪些?

    8 NoSQL数据库有哪些?文章目录 1 键值数据库 2 列族数据库 3 文档数据库 4 图形数据库关系型数据库产品很多 如 MySQL Oracle MicrosoftSQL 等 但它们的基本模型都是关系型数据模型 NoSQL 并没有统一的模型 而且是非关系型的 常见的 NoSQL 数据库包括键值数据库 列族数据库 文档数据库和图形数据库 其具体分类和特点如表所示 NoSQL 数据库分类和特点分类相关产品应用场景数据模型优点缺点键值数据库 Redis Memcache

    2026年3月19日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号