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

最新文章

  1. SQL 查找重复项及批量修改数据成固定格式
  2. 如何解决winows启动后出现grub?
  3. [转]Redis实现分析
  4. Selenium Grid 学习笔记
  5. 蒙特卡洛树搜索算法(UCT): 一个程序猿进化的故事
  6. awk的二维数组
  7. 十五、mysql 分区之 分区管理
  8. Android Studio 模拟器启动问题——黑屏 死机 解决方法
  9. hadoop2.2编程:矩阵相乘简单实现
  10. 【转】Install MATLAB 2013a on CentOS 6.4 x64 with mode silent
  11. oracle11 客户端安装及PLSQL和TOAD中文乱码
  12. Lucene核心--构建Lucene搜索(上篇,理论篇)
  13. CXF.bat
  14. Chapter 2 User Authentication, Authorization, and Security(10):创建包含数据库
  15. 七.django模型系统(一)
  16. Java知多少(25)再谈Java包
  17. RabbitMq(2) 简单消息队列
  18. 【机器学习】K-means聚类算法与EM算法
  19. Windows7设置锁屏密码
  20. 使用c语言计算分期贷款折算年化收益率(内部收益率IRR*12)

热门文章

  1. Java并发编程之同步辅助类
  2. VS2015上OpenCV-2.4.13安装与Hi35xx .jpg/.bmp格式转.bgr格式开发
  3. WPF3D立方体图形展开动画思路
  4. 使用KeepAlived来实现高可用的DR模型
  5. 【linux】驱动-10-pinctrl子系统
  6. 因为这几个TypeScript代码的坏习惯,同事被罚了500块
  7. SpringBoot 使用逆向工程 构建Mapper.xml Dao层(持久层) 实体类
  8. 1036 Boys vs Girls
  9. D - The Frog's Games (二分)
  10. 限制pyqt5应用程序 只允许打开一次