ECMAScript ES6 从一脸懵逼到灵活运用

var let const

var let const 的比较

声明与赋值

  • var声明的变量是可以重新赋值的,也可以重复声明

  • letconst声明的变量都是不可以重复声明的

    ​ 即使在不同作用域内可以出现同名变量,但并不相同,只能在各自的作用域中使用

  • 不同的是, let声明的变量是可以重新赋值的,但 const不行

    ​ 注意:用const声明的变量并不是完全不可以改变的

    ​ 如果用const来声明一个对象,虽然无法给这个对象重新赋值,但是我们可以改变对象的属性值(对象是引用类型变量,只改变对象的属性并不会影响指针指向)

    ​ 如果你也不希望改变属性值的话可以使用Object.freeze()方法

变量作用域

  • varfunction scope即函数作用域

    在函数中声明的变量只能在函数中使用,否则就是一个全局变量

    如果在在iffor等语句里定义的变量你只希望在内部使用,var就无法满足,因为它没有在函数里声明,所以会变成一个全局变量,污染全局作用域

  • letconstblock scope即块级作用域

    一对大括号 { } 所包裹的内容即为一个块级作用域,声明的变量只能在块内使用,在块级作用域外调用则会报错

let 和 const 的使用场景

  1. letconst代替IIFE

    IIFE 即 立即执行函数 ,应用之一就用来生成一个私有变量

    // 例如我们在window对象中有一个name属性,如果直接这样声明一个name变量的话会覆盖属性name的值
    // var name = 'Tom'; // 我们通常会用一个立即执行函数来使变量私有化
    (function () {
    var name = 'Tom';
    })(); // 如果使用 let 或者 const 就可以简单实现,只需要用一对大括号包裹起来,就形成了一个块级作用域
    {
    let name = 'Tom';
    }
  2. for循环

    for (var i = 0; i < 10; i++) {
    
        console.log(i);	// 输出:0 1 2 3 ... 9
    
        // 我们这里用setTimeout来模拟异步请求
    setTimeout(function() {
    console.log('i:' + i);
    // 这里输出了10个 i:10
    // 因为函数是延迟一秒执行的 此时 for 循环已经结束
    }, 1000)
    } // 将 var 改成 let 即可得到想要的结果,但不能使用 const !
  3. ...

临时性死区 Temporal Dead Zone

变量提升是 JavaScript 将变量的声明移至作用域的顶部

console.log(color);		// 不会报错 而是输出 undefined
var color = 'yellow'; // 因为有了变量提升实际上这段代码是这样的 var color;
console.log(color); // 所以这里会输出 undefined
color = 'yellow'; /*
如果将 var 换成 let 则会报 ReferenceError
在ESMAScript 2015 中, let 也会将变量提块级作用域顶部,但你想在块级作用域中变量的声明之前引用的话就会报ReferenceError, 因为它是在临时性死区中的, const 亦是如此
我们要养成在变量之前不要使用它的好习惯
需要注意的是,因为 const 定义的是一个常量,所以声明的同时必须赋初始值,否则会报错
使用建议( in ES6 ):
默认使用 const
当变量需要重新绑定的时候使用 let
尽量不使用 var
*/

Arrow Function 箭头函数

优点:

  1. 简明的语法
  2. 可以隐式返回
  3. 不绑定this

简明的语法

例如我们要用map遍历一个数组使其中的数乘以二返回

const nums = [1, 3, 0, 5];

const double = nums.map(function (num) {
return num * 2;
}); console.log(double); // [2, 6, 0, 10] // 改用箭头函数
const double2 = nums.map((num) => {
return num * 2;
}); console.log(double2); // [2, 6, 0, 10]

箭头函数写法:去掉function关键字, 加上 =>

如果箭头函数只有一个参数的话,()可以省略,没有参数或者有多个参数则必须使用括号并且参数之间用,隔开

隐式返回

显式返回即return关键字加上返回的内容。

箭头函数中的隐式返回:

​ 去掉return关键字 , 去掉 {} , 将表达式写到一行中

用于我们只想简单返回一些内容时,使代码更加简洁

// like this
const double3 = nums.map((num) => num * 2);

注: 因为箭头函数都是匿名函数,匿名函数在递归或者作为回调函数等场景时非常好用,但如果你只想作为一个简单函数的话我们一般把它赋值给一个变量来使用

this问题

在使用箭头函数以前我们经常遇到这样的问题

const Tom = {
name: 'Tom',
hobbies: ['Coding', 'Sleeping', 'Reading'],
showHobbies: function () {
console.log(this); // 对象 Tom
this.hobbies.map(function (hobby) {
console.log(this); // 这里我们打印一下 this 发现竟然是 Window !
console.log(this.name + ' likes ' + hobby);
})
}
} Tom.showHobbies();
/* 输出:
likes Coding
likes Coding
likes Reading
咦,你会发现 Tom 不见了,看来是 this.name 的 this 指向出了问题
*/

因为JS中的this是在运行的时候才绑定的,

这里的showHobbies()是由 对象Tom调用的,所以this指向的是对象Tom

map()方法里的回调函数他不是作为对象的方法调用,也没有使用applycall等方法来改变this指向,所以这里的this指向的是 Window 或者说全局(严格模式下为undefined)

以前我们通常的做法是在这之前var self = this;,然后用self代替this来使用

在ES6中我们可以借助箭头函数来代替这种 hack 写法,因为箭头函数没有自己的this,它的this值是继承它的父级作用域的(词法作用域,由上下文确定)

箭头函数不适用的场景

  1. 作为构造函数,向原型对象中添加方法
  2. 当你真的需要this的时候,例如事件绑定
  3. 需要使用arguments对象时

函数参数默认值

注意:参数中的变量是默认声明的,所以不能再函数内部再次用let或者const进行声明,这样会报错

// 直接在函数的形参后面赋值
function multiply (a = 1, b = 2) {
return a * b;
} multiply(); // 2
multiply(3, 5); // 15
multiply(3); // 6
multiply(, 5); // error
// 一般情况下,我们使用带默认参数的函数应该是函数的最后一个参数
// 但如果非尾部的参数设置了默认值,实际上在我们调用这个函数的时候,这个参数是无法省略的
multiply(undefined, 5); // 5
// 不能使用 null
multiply(null, 5); // 0

模板字符串

在过去我们要组合 变量 和 字符串 的时候需要不停地用+进行连接,这样既繁琐又容易出错而且不易检查。

有了 ES6 的模板字符串就变得容易多了

模板字符串 允许我们用一对反引号 ``来定义字符串,当字符串中需要引用变量的时候只需要用${ }包裹就可以了

里面的变量可以是任意的 JS 表达式,包括对象的属性,甚至是一个函数

const name = 'Tom';
const age = 5;
const text = `${name} is ${age * 5} years old.`; console.log(text); // "Tom is 25 years old."

未完待续。。。

ES6笔记分享 part 1的更多相关文章

  1. ES6笔记分享 part 2

    ECMAScript ES6 从一脸懵逼到灵活运用 接 part 1 New String Methods const id = 'adcd123456x'; const fan = 'I love ...

  2. ES6笔记(5)-- Generator生成器函数

    系列文章 -- ES6笔记系列 接触过Ajax请求的会遇到过异步调用的问题,为了保证调用顺序的正确性,一般我们会在回调函数中调用,也有用到一些新的解决方案如Promise相关的技术. 在异步编程中,还 ...

  3. ES6笔记系列

    ES6,即ECMAScript 6.0,ES6的第一个版本是在2015年发布的,所以又称作ECMAScript 2015 如今距ES6发布已经一年多的时间,这时候才去学,作为一个JSer,羞愧羞愧,还 ...

  4. ES6笔记(1) -- 环境配置支持

    系列文章 -- ES6笔记系列 虽然ES6已经发布一年多了,但在各大浏览器之中的支持度还不是很理想,在这查看ES6新特性支持度 Chrome的最新版本浏览器大部分已经支持,在Node.js环境上支持度 ...

  5. ES6笔记(2)-- let的块级作用域

    系列文章 -- ES6笔记系列 一.函数级作用域 我们都知道,在ES6以前,JS只有函数级作用域,没有块级作用域这个概念 没有块级作用域,有利有弊,利于方便自由,弊于作用域内的变量容易被共享,例如这个 ...

  6. ES6笔记(3)-- 解构赋值

    系列文章 -- ES6笔记系列 解构赋值,即对某种结构进行解析,然后将解析出来的值赋值给相关的变量,常见的有数组.对象.字符串的解构赋值等 一.数组的解构赋值 function ids() { ret ...

  7. ES6笔记(4)-- Symbol类型

    系列文章 -- ES6笔记系列 Symbol是什么?中文意思是标志.记号,顾名思义,它可以用了做记号. 是的,它是一种标记的方法,被ES6引入作为一种新的数据类型,表示独一无二的值. 由此,JS的数据 ...

  8. ES6笔记(6)-- Set、Map结构和Iterator迭代器

    系列文章 -- ES6笔记系列 搞ES6的人也是够无聊,把JS弄得越来越像Java.C++,连Iterator迭代器.Set集合.Map结构都出来了,不知道说什么好... 一.简单使用 1. iter ...

  9. ES6笔记(7)-- Promise异步编程

    系列文章 -- ES6笔记系列 很久很久以前,在做Node.js聊天室,使用MongoDB数据服务的时候就遇到了多重回调嵌套导致代码混乱的问题. JS异步编程有利有弊,Promise的出现,改善了这一 ...

随机推荐

  1. F5 LTM旁路配置四层负载

    网络拓扑图如下: 如上图所示,其中LTM和web1,web2处于同一网络中,外部的client访问请求后端的服务的时候,通过F5 LTM的VS地址,将实际的请求分配到后端两台服务web1和web2上 ...

  2. k8s数据持久化实验

    Step 1:创建PV ============================================ apiVersion: v1kind: PersistentVolumemetadat ...

  3. Elasticsearch介绍和安装

    Elasticsearch介绍和安装 软件包: 链接:https://pan.baidu.com/s/1O_C0JQGfF8sC_OtcCCLNoQ 提取码:3iai 1.1.简介 1.1.1.Ela ...

  4. 基于DDD的微服务设计和开发实战

    你是否还在为微服务应该拆多小而争论不休?到底如何才能设计出收放自如的微服务?怎样才能保证业务领域模型与代码模型的一致性?或许本文能帮你找到答案. 本文是基于 DDD 的微服务设计和开发实战篇,通过借鉴 ...

  5. VMware Workstation 与 Device/Credential Guard 不兼容.在禁用 Device/Credenti

    出现问题的原因: 原因一.出现此问题的原因是Device Guard或Credential Guard与Workstation不兼容. 原因二.Windows系统的Hyper-V不兼容导致. 解决方案 ...

  6. 利用pandas、Ipython来简化数据分析过程

    最近小爬我为了提升数据分析这块儿的技能,学习了pandas库作者Wes Mckinney的数据分析经典书籍<利用Python进行数据分析>,受益良多!里面涉及到Python语言基础.还有编 ...

  7. 开发者请注意:Python2 的最后版本将于 4 月发布,但它确实是在 1 月 1 日就寿命终止了!

    2020 年 1 月 1 日是 Python2 的寿命终止日,这个日期在两年前经"Python之父" Guido van Rossum 宣布,此后一直成为开发者社区翘首以盼的一天. ...

  8. Hive直接读取Hbase及MySQL数据

    0.概述 Hive对外提供了StorageHandler接口,提供了访问各种存储组件中的数据的能力.Hbase提供了HbaseStorageHandler,使得hive可以通过建立外部映射表访问hba ...

  9. 学了java,我才发现台球还可以这样玩!

    桌球小游戏的尝试 桌球是人们日常生活中都能接触到的一种娱乐活动,随着互联网技术的发展,手机上也有了很多桌球小游戏,让人们随时随地都能打两把.   今天分享一个用java编写的桌球小游戏 代码如下:  ...

  10. 1091 N-自守数 (15 分)C语言

    如果某个数 K 的平方乘以 N 以后,结果的末尾几位数等于 K,那么就称这个数为"N-自守数".例如 3×92^​2​​ =25392,而 25392 的末尾两位正好是 92,所以 ...