ES6 入门介绍及使用
- ES6介绍
- let和const
- let和const中存在的问题
- 解构
- 扩展运算符
ES6介绍
ES6 (ECMAScript) 第六版
ECMAScript 是Javascript的一套标准化设置
ES6的内容包括:
1.声明变量的方法(let和const)
2.变量的结解构赋值
3.扩展运算符
4.数据劫持 箭头函数
5.Set Map
6.数组 对象 数值的扩展
7.Promise对象
8.Generator函数
let和const
let和const命令是ES6新增的语法
作用:是用来声明变量 和var的作用一样
let和const的用法注意点几乎一样 只是let在同一作用域内 可以重新赋值 但是不能重复声明
const声明的是常量 声明过后就不能再重新声明或者重新赋值
let声明的变量 只是在let所在的作用域内起作用(变量绑定)
var a = 123;
if (true) {
a = 456;
console.log(a);
// 在下面进行let声明
let a; //------------------------->报错
}
let和const中存在的问题
(1) 作用域的问题
通常情况下 如果需要一个变量在一个规定的作用域内起作用 那么就需要使用function关键字来搭建一个局部作用域
(function(){
var a=1;
}());
console.log(a);
但是在ES6的情况下 引入了let 只要存在{} 就可以形成一个块级作用域 不管是if结构 还是for循环结构 只要有{} 存在,即形成了块级作用域
{
let s=8;
}
console.log(s);
(2) var 声明变量 变量提升的问题
需求:在函数调用时 实时的打印出当前的时间
在if结构里面使用var声明 {}没办法形成块级作用域 那么if结构里面的变量声明就会覆盖掉全局的变量声明
所以打印出来的undefined;
解决办法:在if结构里面使用let声明变量 使其在if结构里面形成一个块级作用域
var time = new Date();
function fn() {
console.log(time);
if (false) {
// var time="明天是父亲节";
let time = "明天是父亲";
}
}
fn();
(3) for循环中 循环变量泄露为全局变量的问题
for(var i=0;i<5;i++){
setTimeout(function(){
console.log(i);
},1000);
console.log(111);
}
console.log(123);
console.log(i);
js语言的一大特性:单线程 同一时间内只做一件事
任务队列:所有的任务都需要排队 前面的执行完 才会执行后面的任务
事件循环:主线程会不断循环的去任务队列里面读取任务(Event Loop)当遇到异步任务完成 或者某个事件被触发
那么相应的回调函数 或者 函数体 就会被拉到主线程里面去执行
for (let i = 0; i < 5; i++) {
setTimeout(function () {
console.log(i);
}, 1000);
console.log(111);
}
console.log(123);
console.log(i);
解构
在ES6中 按照一定的模式 从数组中提取数值 对对应的变量进行赋值的操作 就叫做解构赋值
本质上讲 解构赋值 就是模式匹配
var[a,b,c]=[1,2,3];
console.log(a,b,c); //1 2 3
特点:
1.如果想要解构赋值成功 那么就必须保证两边的模式完全一样
var[a,b,c]=[1,[2],{name:"lucy"}];
console.log(a,b,c); //1 Array(1) 0: 2 Object {name:"lucy"}
2.如果解构不成功 那么变量的值就等于undefined
left[r]=[];
console.log(r); //undefined 这个就像var 声明了变量之后 不进行赋值
left[s,t]=[3];
console.log(s,t) //3,undefined 这个也是属于解构不成功 因为数值不够
3.不完全解构的情况下 也可以进行解构赋值 只是后面放数值的数组都有多的数字
不完全解构 :指的是等号左右两边模式一样 但是只匹配到右边的一部分数据
let[x,y]=[1,2,3];
console.log(x,y); //1 2
4.如果等号右边不是数组 那么就会报错 因为模式一样
注意点
1.解构赋值允许设置默认值 但是如果要启用默认值 那么这个变量的值就必须严格等于undefined
let[a,b]=[1,2];
let[a,b="abc"]=[1,2];
console.log(a,b); //1 2
let[a,b="abc"]=[1];
console.log(a,b); //1 "abc"
let[a,b="abc"]=[1,null];
console.log(a,b); //1 "null"
2.如果设置的默认是一个表达式 那么这个表达式只是在需要启用默认值的时候才会运算
function fn(){
console.log(123);
// return 123
}
let[s=fn()]=[12];
console.log(s); //12
let[s=fn()]=[];
console.log(s); //undefined 这里的undefined 不是[]里面的undefined 而是fn调用之后的返回值undefined
3.默认值可以使用其他变量 但是前提是赋值的这个变量必须是提前声明过的
let d=3;
let[x=d]=[];
console.log(x); //3
let[x=2,y=x]=[];
console.log(x,y); //2 2
// let[x=y,y=2]=[];
// console.log(x,y); //报错
let[x=2,y=x]=[8];
console.log(x,y); //8 8
扩展运算符
扩展运算符 (…)
传统的数组遍历
var arr=[100,200,300];
console.log(arr[0]);
console.log(arr[1]);
console.log(arr[2]);
for(var i=0;i<arr.length;i++){
console.log(arr[i]);
}
用扩展运算符来完成数组的赋值
var arr=[100,200,300];
var arr2 = [...arr];
console.log(arr2);// 100 200 300
与直接赋值的区别:
直接赋值 修改了原数组的值 arr1里面的值也会发生改变 因为他们指向同一块内存空间
var arr=[100,200,300];
var arr1=arr;
arr[1]=20;
console.log(arr1);
console.log([...arr]);
使用扩展运算符 就是一个一个加到新数组里面去 所以即使原数组元素发生变化 也不会影响新数组
var arr2=[...arr];
arr[0]=10;
console.log(arr2);
扩展运算符的作用
- 数组合并 这里不管是concat方法 还是扩展运算符 都是浅拷贝
如果修改了原数组的指向 就会同步反应到新数组 就是浅拷贝
var arr1=[1,2,3];
var arr2=[10,20,30];
arr1[2]=33;
var arrCon=arr1.concat(arr2);
console.log(arrCon)
var arrSp=[...arr1,...arr2];
console.log(arrSp);
//这里就证明了合并后的数组和合并前的数组指向同一片内存空间 所以证明了都是浅拷贝
console.log(arrSp[0]===arr1[0]); //true
console.log(arrCon[0]===arr1[0]); //true
- 数组的拷贝
var arr=[1,[3,[12,15,[15,18]]],{name:"lili"}];
var arrSp=[...arr];
console.log(arrSp)
- 与解构赋值相结合
(1). 与解构赋值相结合 给变量和数组赋值
如果是普通变量 那么就按照模式赋值 如果使用了扩展运算符 那么就是后面的值依次放入数组
var [s,...t]=[1,2,3,4,5];
console.log(s,t); //1 [2,3,4,5]
如果等号右边是空数组 那么仅仅是声明 变量就是undefined 数组就是[]
var [s,...t]=[]
console.log(s,t); //undefined []
(2). 如果将扩展运算符用于数组赋值 只能放在参数的最后一位 否则就会报错
let[a,...b,c]=[1,2,3,2,9];
let[...b,a,c]=[1,2,3,2,9];
console.log(a,b,c) //Rest element must be last element
- 扩展运算符可以将字符串转成真正的数组
console.log([..."hello"]);
var str="hello";
console.log(str.split(""));
- 只有函数调用时 扩展运算符才可以放在圆括号里面 否则这种写法就直接报错
var arr1=[12,45,25];
console.log([...arr1]); //12 45 25
console.log(...arr1); //12 45 25
console.log((...arr1)); //报错