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

为什么叫Arrow Function?因为它的定义用的就是一个箭头:

语法:

  1. //1、没有形参的时候
  2. let fun = () => console.log('我是箭头函数');
  3. fun();
  4. //2、只有一个形参的时候()可以省略
  5. let fun2 = a => console.log(a);
  6. fun2('aaa');
  7.  
  8. //3、俩个及俩个以上的形参的时候
  9. let fun3 = (x,y) =>console.log(x,y); //函数体只包含一个表达式则省略return 默认返回
  10. fun3(24,44);
  11.  
  12. //4、俩个形参以及函数体多条语句表达式
  13. let fun4 = (x,y) => {
  14.   console.log(x,y);
  15.   return x+y; //必须加return才有返回值
  16. }
    //5、如果要返回对象时需要用小括号包起来,因为大括号被占用解释为代码块了,正确写法
    let fun5 = ()=>({ foo: x }) //如果x => { foo: x }  //则语法出错

那么箭头函数有哪些特点?

  • 更简洁的语法
  • 没有this
  • 不能使用new 构造函数
  • 不绑定arguments,用rest参数...解决
  • 使用call()和apply()调用
  • 捕获其所在上下文的 this 值,作为自己的 this 值
  • 箭头函数没有原型属性
  • 不能简单返回对象字面量
  • 箭头函数不能当做Generator函数,不能使用yield关键字
  • 箭头函数不能换行

相比普通函数更简洁的语法

箭头函数

  1. var a = ()=>{
  2. return 1;
  3. }

相当于普通函数

  1. function a(){
  2. return 1;
  3. }

没有this

在箭头函数出现之前,每个新定义的函数都有其自己的 this 值

  1. var myObject = {
  2. value:1,
  3. getValue:function(){
  4. console.log(this.value)
  5. },
  6. double:function(){
  7. return function(){  //this指向double函数内不存在的value
  8. console.log(this.value = this.value * 2);
  9. }
  10. }
  11. }
  12. /*希望value乘以2*/
  13. myObject.double()(); //NaN
  14. myObject.getValue(); //

使用箭头函数

  1. var myObject = {
  2. value:1,
  3. getValue:function(){
  4. console.log(this.value)
  5. },
  6. double:function(){
  7. return ()=>{
  8. console.log(this.value = this.value * 2);
  9. }
  10. }
  11. }
  12. /*希望value乘以2*/
  13. myObject.double()(); //
  14. myObject.getValue(); //

不能使用new

箭头函数作为匿名函数,是不能作为构造函数的,不能使用new

  1. var B = ()=>{
  2. value:1;
  3. }
  4.  
  5. var b = new B(); //TypeError: B is not a constructor

不绑定arguments,用rest参数...解决

  1. /*常规函数使用arguments*/
  2. function test1(a){
  3. console.log(arguments); //
  4. }
  5. /*箭头函数不能使用arguments*/
  6. var test2 = (a)=>{console.log(arguments)} //ReferenceError: arguments is not defined
  7. /*箭头函数使用reset参数...解决*/
  8. let test3=(...a)=>{console.log(a[1])} //
  9.  
  10. test1(1);
  11. test2(2);
  12. test3(33,22,44);

使用call()和apply()调用

由于 this 已经在词法层面完成了绑定,通过 call() 或 apply() 方法调用一个函数时,只是传入了参数而已,对 this 并没有什么影响:

  1. var obj = {
  2. value:1,
  3. add:function(a){
  4. var f = (v) => v + this.value; //a==v,3+1
  5. return f(a);
  6. },
  7. addThruCall:function(a){
  8. var f = (v) => v + this.value; //此this指向obj.value
  9. var b = {value:2};
  10. return f.call(b,a); //f函数并非指向b,只是传入了a参数而已
  11.  
  12. }
  13. }
  14.  
  15. console.log(obj.add(3)); //
  16. console.log(obj.addThruCall(4)); //

捕获其所在上下文的 this 值,作为自己的 this 值

  1. var obj = {
  2. a: 10,
  3. b: function(){
  4. console.log(this.a); //
  5. },
  6. c: function() {
  7. return ()=>{
  8. console.log(this.a); //
  9. }
  10. }
  11. }
  12. obj.b();
  13. obj.c()();

箭头函数没有原型属性

  1. var a = ()=>{
  2. return 1;
  3. }
  4.  
  5. function b(){
  6. return 2;
  7. }
  8.  
  9. console.log(a.prototype);//undefined
  10. console.log(b.prototype);//object{...}

不能简单返回对象字面量

如果要返回对象时需要用小括号包起来,因为大括号被占用解释为代码块了,正确写法

  1. let fun5 = ()=>({ foo: x }) //如果x => { foo: x } //则语法出错

箭头函数不能当做Generator函数,不能使用yield关键字

箭头函数不能换行

  1. let a = ()
  2. =>1; //SyntaxError: Unexpected token =>

ES6——箭头函数与普通函数的区别的更多相关文章

  1. Es6中箭头函数与普通函数的区别

    Es6中箭头函数与普通函数的区别? 普通function的声明在变量提升中是最高的,箭头函数没有函数提升 箭头函数没有属于自己的this,arguments 箭头函数不能作为构造函数,不能被new,没 ...

  2. ES6箭头函数(箭头函数和普通函数的区别)

    箭头函数 一个参数 // 只有一个参数 // f : 函数名称 // v : 函数参数 // v+v : 函数内容 let f=v=> v+v console.log(f(10)) //20 两 ...

  3. ES6中的箭头函数与普通函数的区别

    箭头函数与普通函数的区别 1.语法上更加简洁.清晰 基本语法: // 关于箭头函数的参数 // 如果箭头函数没有参数,直接写一个括号即可 let fun1 = () => { console.l ...

  4. es6 箭头函数(arrow function) 学习笔记

    箭头函数有两个好处. 1.他们比传统函数表达式简洁. const arr = [1, 2, 3]; const squares = arr.map(x => x * x); // 传统函数表达式 ...

  5. ES6 — 箭头函数

    一 为什么要有箭头函数 我们在日常开发中,可能会需要写类似下面的代码 const Person = { 'name': 'little bear', 'age': 18, 'sayHello': fu ...

  6. js this问题和es6箭头函数this问题

    JS中this的四种用法 1.在一般函数方法中使用 this 指代全局对象 function test(){ this.x = 1; alert(this.x); } test(); //1 2.作为 ...

  7. JavaScript ES6箭头函数指南

    前言 胖箭头函数(Fat arrow functions),又称箭头函数,是一个来自ECMAScript 2015(又称ES6)的全新特性.有传闻说,箭头函数的语法=>,是受到了CoffeeSc ...

  8. ES6 箭头函数中的 this?你可能想多了(翻译)

    箭头函数=>无疑是ES6中最受关注的一个新特性了,通过它可以简写 function 函数表达式,你也可以在各种提及箭头函数的地方看到这样的观点——“=> 就是一个新的 function”. ...

  9. ES6箭头函数(Arrow Functions)

    ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器). 一.语法 1. 具有一个参数的简单函数 var single = a => a single('he ...

随机推荐

  1. Docker版本与centos和ubuntu环境下docker安装介绍

    # Docker版本与安装介绍 * Docker-CE 和 Docker-EE * Centos 上安装 Docker-CE * Ubuntu 上安装 Docker-CE ## Docker-CE和D ...

  2. springboot中动态修改logback日志级别

    springboot中动态修改logback日志级别 在spring boot中使用logback日志时,项目运行中,想要修改日志级别. 代码如下: import org.slf4j.Logger; ...

  3. cmd命令查看已连接的WiFi密码

      实验环境:Windows 10.命令提示符(管理员权限) 一.CMD命令查看WiFi密码 使用方法: ①.运行CMD(命令提示符) (确保无线网卡启用状态)②.输入命令查看WiFi配置文件:  # ...

  4. 洛谷 P1091合唱队列

    吾王剑之所指,吾等心之所向                           ——<Fate/stay night> 题目:https://www.luogu.org/problem/P ...

  5. 阿里雷卷:Reactive 基金会的成立将对开发方式带来哪些影响?

    作者 | 赵钰莹 近日,Linux 基金会宣布成立 Reactive 基金会.对于 Reactive,各位开发者应该并不陌生,尤其是 Node.js 开发者,但真正了解并意识到这件事情对开发方式带来的 ...

  6. Lottie在手,动画我有:ios/Android/Web三端复杂帧动画解决方案

      为什么需要Lottie 在相对复杂的移动端应用中,我们可能会需要使用到复杂的帧动画.例如: 刚进入APP时候可能会看到的入场小动画,带来愉悦的视觉享受 许多Icon的互动变化比较复杂多变的时候,研 ...

  7. 新手学习FFmpeg - 调用API调整视频局部速率

    通过修改setpts代码实现调整视频部分的播放速率. 完整代码可参考: https://andy-zhangtao.github.io/ffmpeg-examples/ 在前面提到了PTS/DTS/T ...

  8. 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业

    1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...

  9. 安装Winservices服务出现“设置服务登录”

    安装服务时出现  设置服务登录  窗口 别紧张   将serviceProcessInstaller1   Account 设置为LocalSystem 即可

  10. 使用CoordinatorLayout打造各种炫酷的效果

    使用CoordinatorLayout打造各种炫酷的效果 自定义Behavior -- 仿知乎,FloatActionButton隐藏与展示 NestedScrolling 机制深入解析 一步步带你读 ...