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 ...
随机推荐
- Docker版本与centos和ubuntu环境下docker安装介绍
# Docker版本与安装介绍 * Docker-CE 和 Docker-EE * Centos 上安装 Docker-CE * Ubuntu 上安装 Docker-CE ## Docker-CE和D ...
- springboot中动态修改logback日志级别
springboot中动态修改logback日志级别 在spring boot中使用logback日志时,项目运行中,想要修改日志级别. 代码如下: import org.slf4j.Logger; ...
- cmd命令查看已连接的WiFi密码
实验环境:Windows 10.命令提示符(管理员权限) 一.CMD命令查看WiFi密码 使用方法: ①.运行CMD(命令提示符) (确保无线网卡启用状态)②.输入命令查看WiFi配置文件: # ...
- 洛谷 P1091合唱队列
吾王剑之所指,吾等心之所向 ——<Fate/stay night> 题目:https://www.luogu.org/problem/P ...
- 阿里雷卷:Reactive 基金会的成立将对开发方式带来哪些影响?
作者 | 赵钰莹 近日,Linux 基金会宣布成立 Reactive 基金会.对于 Reactive,各位开发者应该并不陌生,尤其是 Node.js 开发者,但真正了解并意识到这件事情对开发方式带来的 ...
- Lottie在手,动画我有:ios/Android/Web三端复杂帧动画解决方案
为什么需要Lottie 在相对复杂的移动端应用中,我们可能会需要使用到复杂的帧动画.例如: 刚进入APP时候可能会看到的入场小动画,带来愉悦的视觉享受 许多Icon的互动变化比较复杂多变的时候,研 ...
- 新手学习FFmpeg - 调用API调整视频局部速率
通过修改setpts代码实现调整视频部分的播放速率. 完整代码可参考: https://andy-zhangtao.github.io/ffmpeg-examples/ 在前面提到了PTS/DTS/T ...
- 2019-2020-1 20199314 <Linux内核原理与分析>第二周作业
1.基础学习内容 1.1 冯诺依曼体系结构 计算机由控制器.运算器.存储器.输入设备.输出设备五部分组成. 1.1.1 冯诺依曼计算机特点 (1)采用存储程序方式,指令和数据不加区别混合存储在同一个存 ...
- 安装Winservices服务出现“设置服务登录”
安装服务时出现 设置服务登录 窗口 别紧张 将serviceProcessInstaller1 Account 设置为LocalSystem 即可
- 使用CoordinatorLayout打造各种炫酷的效果
使用CoordinatorLayout打造各种炫酷的效果 自定义Behavior -- 仿知乎,FloatActionButton隐藏与展示 NestedScrolling 机制深入解析 一步步带你读 ...