ES6——箭头函数与普通函数的区别
ES6标准新增了一种新的函数:Arrow Function(箭头函数)。
为什么叫Arrow Function?因为它的定义用的就是一个箭头:
语法:
//1、没有形参的时候
let fun = () => console.log('我是箭头函数');
fun();
//2、只有一个形参的时候()可以省略
let fun2 = a => console.log(a);
fun2('aaa'); //3、俩个及俩个以上的形参的时候
let fun3 = (x,y) =>console.log(x,y); //函数体只包含一个表达式则省略return 默认返回
fun3(24,44); //4、俩个形参以及函数体多条语句表达式
let fun4 = (x,y) => {
console.log(x,y);
return x+y; //必须加return才有返回值
}
//5、如果要返回对象时需要用小括号包起来,因为大括号被占用解释为代码块了,正确写法
let fun5 = ()=>({ foo: x }) //如果x => { foo: x } //则语法出错
那么箭头函数有哪些特点?
- 更简洁的语法
 - 没有this
 - 不能使用new 构造函数
 - 不绑定arguments,用rest参数...解决
 - 使用call()和apply()调用
 - 捕获其所在上下文的 this 值,作为自己的 this 值
 - 箭头函数没有原型属性
 - 不能简单返回对象字面量
 - 箭头函数不能当做Generator函数,不能使用yield关键字
 - 箭头函数不能换行
 
相比普通函数更简洁的语法
箭头函数
var a = ()=>{
return 1;
}
相当于普通函数
function a(){
  return 1;
}
没有this
在箭头函数出现之前,每个新定义的函数都有其自己的 this 值
var myObject = {
  value:1,
  getValue:function(){
    console.log(this.value)
  },
  double:function(){
    return function(){  //this指向double函数内不存在的value
      console.log(this.value = this.value * 2);
    }
  }
}
/*希望value乘以2*/
myObject.double()();  //NaN
myObject.getValue();  //
使用箭头函数
var myObject = {
  value:1,
  getValue:function(){
    console.log(this.value)
  },
  double:function(){
    return ()=>{
      console.log(this.value = this.value * 2);
    }
  }
}
/*希望value乘以2*/
myObject.double()();  //
myObject.getValue();  //
不能使用new
箭头函数作为匿名函数,是不能作为构造函数的,不能使用new
var B = ()=>{
  value:1;
}
var b = new B(); //TypeError: B is not a constructor
不绑定arguments,用rest参数...解决
/*常规函数使用arguments*/
function test1(a){
console.log(arguments); //
}
/*箭头函数不能使用arguments*/
var test2 = (a)=>{console.log(arguments)} //ReferenceError: arguments is not defined
/*箭头函数使用reset参数...解决*/
let test3=(...a)=>{console.log(a[1])} // test1(1);
test2(2);
test3(33,22,44);
使用call()和apply()调用
由于 this 已经在词法层面完成了绑定,通过 call() 或 apply() 方法调用一个函数时,只是传入了参数而已,对 this 并没有什么影响:
var obj = {
  value:1,
  add:function(a){
    var f = (v) => v + this.value; //a==v,3+1
    return f(a);
  },
  addThruCall:function(a){
    var f = (v) => v + this.value; //此this指向obj.value
    var b = {value:2};
    return f.call(b,a); //f函数并非指向b,只是传入了a参数而已
  }
}
console.log(obj.add(3));    //
console.log(obj.addThruCall(4));    //
捕获其所在上下文的 this 值,作为自己的 this 值
var obj = {
  a: 10,
  b: function(){
    console.log(this.a); //
  },
  c: function() {
     return ()=>{
           console.log(this.a); //
     }
  }
}
obj.b();
obj.c()();
箭头函数没有原型属性
var a = ()=>{
  return 1;
}
function b(){
  return 2;
}
console.log(a.prototype);//undefined
console.log(b.prototype);//object{...}
不能简单返回对象字面量
如果要返回对象时需要用小括号包起来,因为大括号被占用解释为代码块了,正确写法
let fun5 = ()=>({ foo: x })   //如果x => { foo: x }  //则语法出错
箭头函数不能当做Generator函数,不能使用yield关键字
箭头函数不能换行
let a = ()
=>1; //SyntaxError: Unexpected token =>
ES6——箭头函数与普通函数的区别的更多相关文章
- Es6中箭头函数与普通函数的区别
		
Es6中箭头函数与普通函数的区别? 普通function的声明在变量提升中是最高的,箭头函数没有函数提升 箭头函数没有属于自己的this,arguments 箭头函数不能作为构造函数,不能被new,没 ...
 - ES6箭头函数(箭头函数和普通函数的区别)
		
箭头函数 一个参数 // 只有一个参数 // f : 函数名称 // v : 函数参数 // v+v : 函数内容 let f=v=> v+v console.log(f(10)) //20 两 ...
 - ES6中的箭头函数与普通函数的区别
		
箭头函数与普通函数的区别 1.语法上更加简洁.清晰 基本语法: // 关于箭头函数的参数 // 如果箭头函数没有参数,直接写一个括号即可 let fun1 = () => { console.l ...
 - es6 箭头函数(arrow function) 学习笔记
		
箭头函数有两个好处. 1.他们比传统函数表达式简洁. const arr = [1, 2, 3]; const squares = arr.map(x => x * x); // 传统函数表达式 ...
 - ES6 — 箭头函数
		
一 为什么要有箭头函数 我们在日常开发中,可能会需要写类似下面的代码 const Person = { 'name': 'little bear', 'age': 18, 'sayHello': fu ...
 - js this问题和es6箭头函数this问题
		
JS中this的四种用法 1.在一般函数方法中使用 this 指代全局对象 function test(){ this.x = 1; alert(this.x); } test(); //1 2.作为 ...
 - JavaScript ES6箭头函数指南
		
前言 胖箭头函数(Fat arrow functions),又称箭头函数,是一个来自ECMAScript 2015(又称ES6)的全新特性.有传闻说,箭头函数的语法=>,是受到了CoffeeSc ...
 - ES6 箭头函数中的 this?你可能想多了(翻译)
		
箭头函数=>无疑是ES6中最受关注的一个新特性了,通过它可以简写 function 函数表达式,你也可以在各种提及箭头函数的地方看到这样的观点——“=> 就是一个新的 function”. ...
 - ES6箭头函数(Arrow Functions)
		
ES6可以使用“箭头”(=>)定义函数,注意是函数,不要使用这种方式定义类(构造器). 一.语法 1. 具有一个参数的简单函数 var single = a => a single('he ...
 
随机推荐
- VS Code 前端开发常用快捷键插件
			
一.vs code 的常用快捷键 1.注释:a) 单行注释:[ctrl+k,ctrl+c] 或 ctrl+/ b) 取消单行注释:[ctrl+k,ctrl+u] (按下ctrl不放,再按k + u) ...
 - Keras之注意力模型实现
			
学习的一个github上的代码,分析了一下实现过程.代码下载链接:https://github.com/Choco31415/Attention_Network_With_Keras 代码的主要目标是 ...
 - JDK、Spring和Mybatis中使用到的设计模式
			
一.JDK中的设计模式 (1)结构性模式 1.适配器模式 java.util.Arrays#asList() java.io.InputStreamReader(InputStream) java.i ...
 - idea中applicationContext-dao.xml文件中Cannot resolve file***** :spring xml model validation问题
			
访问不了classpath下的文件夹中的文件 解决办法如下:(问题出在我创建的resources文件夹是一个普通的文件夹) 1.本来是普通的文件夹 2.ctrl+shift+alt+s打开如下界面: ...
 - Git客户端下载
			
链接:http://pan.baidu.com/s/1eRXsITO 密码:4i6e
 - 基于RMAN搭建DataGuard,使用Broker管理DataGuard
			
一.环境准备 1.数据库软件准备 (1).在主节点,安装单机数据库软件并创建数据库. (2).在备库, 安装单机数据库软件, 但是不创建数据库. 2.操作系统配置 在/etc/hosts下面配置主机名 ...
 - Java面试-interrupt
			
我们都知道,Java中停止一个线程不能用stop,因为stop会瞬间强行停止一个线程,且该线程持有的锁并不能释放.大家多习惯于用interrupt,那么使用它又有什么需要注意的呢? interrupt ...
 - MyBatis返给前端正确的时间格式
			
前台获取位时间戳,后端解决办法之一 问题描述:前端获取后台接口返回的数据,时间是long类型的时间戳而不是时间类型2019-09-25 17:07:32 项目: JAVA web 工具:eclipse ...
 - alpha测试和beta测试的区别
			
alpha测试版,有点相当于内部测试,一般开发人员在场 ,是由用户做测试,但开发人员在场,一般是请用户到开发现场去测试 beta测试版,完全交给用户,由用户做测试,返回测试报告,相当于发行前的一 ...
 - Weblogic任意文件上传漏洞(CVE-2018-2894)复现
			
使用docker搭建漏洞测试环境 micr067@test:~/vulhub/weblogic/CVE-2018-2894$ sudo docker-compose build weblogic us ...