ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在 2015 年 6 月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。

let与const

1、let用来定义变量,const用来定义常量。

2、有块级作用域

for(let i=0;i<5;i++){
setTimeOut(()=>{
console.log(i);//0-4
}, 3000)
}

vs

for(var i=0;i<5;i++){
setTimeout(()=>{
console.log(i);//55555
}, 3000)//用闭包解决
}

写到这里之前有一次面试的时候,一个面试官说let的块级作用域是怎么实现的?

这个问题其实是在blue的ES6课程上有讲过,就是let相当于实现了一个闭包来解决块级作用域

if(true){
let test = 1;
}
console.log(test);//test is not defined
if(true){
var test1 = 2;
}
console.log(test1);//2

3、没有变量提升

console.log(a);
var a = 1;//undefined
console.log(b);
let b = 2;//b is not defined

4、暂时性死区

var i = 2;
{
var i = 1;
}
console.log(i);//1 let z = 2;
{
let z = 1;
}
console.log(z);//2

箭头函数

普通函数

  • 属于谁,谁调用,指向谁,故指向obj

    区别:
var obj = {
a: function(){
console.log(this);
console.log(1);
}
}
obj.a();//执行obj中的a()函数
obj.a;//函数本身

)

箭头函数

  • 没有独立的作用域,即没有自己的this,指向obj的作用域window
var obj = {
b: function(){
//属于谁,谁调用,指向谁,故指向obj
console.log(this);
},
a: ()=>{
//没有自己的this,指向obj的作用域window
console.log(this);
}
}
obj.b();
obj.a();

  • 不能做构造函数
let Animal = function(){};
let animal = new Animal(); let Animal = ()=>{};
let animal = new Animal();
  • 没有prototype
let commonFn = function(){};
let arrowFn = ()=>{};
console.log(commonFn.prototype);//{constructor: ƒ}
console.log(arrowFn.prototype);//undefined

模板字符串

基本用法

let name = 'Jomsou'
let str = `
<div>
<h1 class="title">${name}</h1>
</div>
`;
document.querySelector('body').innerHTML = str;

Promise

Promise的那些事儿

class

ES6开始,JavaScript正式有了类的概念,用类来实现面向对象。

关键字:class、constructor、extends、super

class Person {
constructor(name,age){
this.name = name;
this.age = age;
}
getName(){
return this.name;
}
getAge(){
return this.age;
}
} class Man extemds Person {
constructor(name, age, sex){
super(name, age);
this.sex = sex;
}
getSex(){
return this.sex;
}
}

Object

Object.keys():返回对象的key值数组

Object.assign(): 整合,浅拷贝

//以前
var name = 'Jomsou';
var age = 23;
var obj1 = {
name: name,
age: age,
getName: function() {
return this.name;
}
}
obj1.getName();
let name = 'Jomsou';
let age = 23;
let obj = {
name,
age,
getName(){
return this.name;
},
['get'+'Age'](){
return this.age;
}
}
Object.keys(obj)

Symbol

一种基本的数据类型,创建后的值是唯一的

1、Symbol的创建

var sy = Symbol(value)

2、Symbol有toString方法

console.log(Symbol('1').toString())//'Symbol(1)'

3、Symbol可以转化成boolean

console.log(!Symbol);//Symbol可以转化成boolean

4、Symbol不能转化成数字

console.log(Symbol(1)+1);//error

5、相同的key值的Symbol.for创建symbol相等

let zf2 = Symbol.for('zhufeng');
let zf3 = Symbol.for('zhufeng');
console.log(zf2==zf3)

6、Symbol.keyFor只能找出有Symbol.for创建的symbol

let zf2 = Symbol.for('zhufeng');
let zf3 = Symbol.for('zhufeng');
console.log(zf2==zf3)//相同的key值的Symbol.for创建symbol相等
console.log(Symbol.keyFor(zf2));
console.log(Symbol.keyFor(sy1));//Symbol.keyFor只能找出有Symbol.for创建的symbol

eg:

var sy1 = Symbol();//Symbol的创建, var sy = Symbol(value)
var sy2 = Symbol();
console.log(typeof sy1);
console.log(sy1 == sy2);
let obj = {
sy1: 'haha',
[sy1]: 'zf'
};
obj[sy2] = 'zf';
console.log(obj);
//console.log(Symbol(1)+1);
console.log(!Symbol);//Symbol可以转化成boolean
console.log(Symbol('1').toString())//Symbol有toString方法
let zf2 = Symbol.for('zhufeng');
let zf3 = Symbol.for('zhufeng');
console.log(zf2==zf3)//相同的key值的Symbol.for创建symbol相等
console.log(Symbol.keyFor(zf2));
console.log(Symbol.keyFor(sy1));//Symbol.keyFor只能找出有Symbol.for创建的symbol

Set

1、类似数组 只有value 没有键key

2、通过构造函数方式创建一个Set实例

var s1 = new Set([1, 2, 3, 4, 5]);
var s2 = new Set("12345");

3、参数是一个数组(或者是类似数组只要是有iterable接口)

4、有iterable接口: 数组、arguments、元素集合、Set、Map、字符串

var arr1 = [1, 2, 3, 4, 5];
console.log(arr1);
var s1 = new Set([1, 2, 3, 4, 5]);
var s2 = new Set("12345");
console.log(s1);
console.log(s2);
function fn(){
console.log(new Set(arguments));
}
fn(1, 2, 3, 4, 5);

5、会默认去重

function unique(arr){
var arrSet = new Set(arr);
return Array.from(arrSet);
//return [...new Set(arr)];
}
console.log(unique([1, 1, 2, 5, 2, 5, 6, 5]));//[1, 2, 5, 6]

6、size->个数

add->如果之前没有,则加上,有就不加,返回增加后的Set实例 (可以实现链式写法),参数一次一个

clear->情况, 没有返回值,undefined,没有参数

delete->删除,返回值是布尔值 如果里面有这一项删除成功true, 没有这一项删除失败false

has->判断有没有此项,返回布尔值

s1.add('jomsou');
s1.add(1);
console.log(s1);
var b = s1.delete(1);
var c = s1.delete(10);
console.log(b+' '+ c+' '+s1);
console.log(s1.has(5));

forEach->遍历

Set实例只有value没有key

item,index: 当前项value

entires: 当前Set实例

s1.forEach((item, value, entries)=>{
console.log(item, value, entries);
})

keys->遍历接口

key: 仍然是value

values

entries->[item, val]

for(var key of s1.keys()){
console.log(key);
}
for(var val of s1.values()){
console.log(val);
}
for(var entrie of s1.entries()){
console.log(entrie);
}
console.log(s1.clear())

应用

//并集
function add(arr1, arr2){
return [...new Set([...arr1, ...arr2])];
}
console.log(add(arr1, arr2));
//交集
function same(arr1, arr2){
return arr1.filter(item=>arr2.includes(item));
}
console.log(same(arr1, arr2));
//差集
function diff(arr1, arr2){
return add(arr1, arr2).filter(item=>!same(arr1, arr2).includes(item))
}
console.log(diff(arr1, arr2));

ES6知识总结的更多相关文章

  1. es6知识总结--3

    es6知识总结--3 es6对咱们es3,es5的数据类型进行了升级下边说新APIs! js数据类型有Number.String .oject.Boolean.Null.Undefined六种数据类型 ...

  2. 前端项目中常用es6知识总结 -- 箭头函数及this指向、尾调用优化

    项目开发中一些常用的es6知识,主要是为以后分享小程序开发.node+koa项目开发以及vueSSR(vue服务端渲染)做个前置铺垫. 项目开发常用es6介绍 1.块级作用域 let const 2. ...

  3. ES6知识整理(4)--数组的扩展

    最近工作比较忙,基本每天都会加班到很晚.处理一些客户端兼容问题以及提升用户体验的优化.也将近一周没更文了,现在继续es6的学习总结. 上篇回顾 ES6知识整理(三)--函数的扩展 扩展运算符 形式是3 ...

  4. 前端项目中常用es6知识总结 -- Async、Await让异步美如画

    项目开发中一些常用的es6知识,主要是为以后分享小程序开发.node+koa项目开发以及vueSSR(vue服务端渲染)做个前置铺垫. 项目开发常用es6介绍 1.块级作用域 let const 2. ...

  5. 前端项目中常用es6知识总结 -- Promise逃脱回调地狱

    项目开发中一些常用的es6知识,主要是为以后分享小程序开发.node+koa项目开发以及vueSSR(vue服务端渲染)做个前置铺垫. 项目开发常用es6介绍 1.块级作用域 let const 2. ...

  6. 前端项目中常用es6知识总结 -- let、const及数据类型延伸

    项目开发中一些常用的es6知识,主要是为以后分享小程序开发.node+koa项目开发以及vueSSR(vue服务端渲染)做个前置铺垫. 项目开发常用es6介绍 1.块级作用域 let const  2 ...

  7. ES6知识整理(1)--let和const命令

    最近准备在业余空闲时间里一边学习ES6,一边整理相关知识.只有整理过的学习才是有效的学习.也就是学习之后要使用和整理成文,才是正在的学到了... 那么现在开始 LINK START!(首先是第一讲,前 ...

  8. 开发中常用的es6知识

    结合实际开发,开发中常用的es6的知识: 1.新增let和const命令: ES6 新增了let命令,用来声明变量.它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效: cons ...

  9. ES6知识整理(10)--class的继承

    (这是es6的第10篇文章.说真的这样的总结之后虽然直观了许多,但是消耗的时间有点长,或许是知识比较复杂的原因吧) 类的继承 有个A类,B类继承A类,那B类实例就可以使用A类实例的所以属性和方法.不包 ...

  10. ES6知识整理(5)--对象的扩展

    个人开这个公众号的初心是为了积累知识,因此并没有做什么推广,再说自己也不知道怎么推广,推广之后又能干些什么.已经将近10天没发文章了,虽然每天都加班,但也不会一点时间都没有,有时还是会懒癌发作不想学习 ...

随机推荐

  1. 基于 SOA 概念 RPC 框架 的 消息中心 云部署 设计 漫谈

    一.背景 假设有一个系统的最大并发量有2000TPS左右.同时该系统有闲时和忙时,希望可以随时进行拓展和削减服务能力,以节省服务器费用开销. 该系统能提供站内消息.短信.app消息.邮箱的一个消息系统 ...

  2. Android新特性介绍,ConstraintLayout完全解析

    今天给大家带来2017年的第一篇文章,这里先祝大家新年好. 本篇文章的主题是ConstraintLayout.其实ConstraintLayout是Android Studio 2.2中主要的新增功能 ...

  3. thymeleaf(二)

    项目demo     http://pan.baidu.com/s/1wg6PC 学习资料网址  http://www.blogjava.net/bjwulin/archive/2013/02/07/ ...

  4. laravel 5.4 导出excel表格

    1.在laravel根目录下面找到一个composer.json文件 打开并在require下面加上一句话,如图所示: 注:以后这个excel的版本号可能还会修改 2.执行 composer inst ...

  5. thinkphp5中使用phpmailer实现发送邮件功能(转载)

    一.开启SMTP服务(使用php发送邮件需要用到SMTP服务,这里以163邮箱的SMTP服务为例). 1.登录163邮箱,在首页上找到“设置”. 2.选择开启的服务,一般都全选,POP3/SMTP/I ...

  6. 记一次Springboot启动异常

    启动Springboot项目报以下异常: org.springframework.context.ApplicationContextException: Unable to start web se ...

  7. Redis的学习笔记

    一.Redis简介 1.关于关系型数据库和nosql数据库 关系型数据库是基于关系表的数据库,最终会将数据持久化到磁盘上,而nosql数据     库是基于特殊的结构,并将数据存储到内存的数据库.从性 ...

  8. 印刷行业合版BOM全阶维护示例

    先看看基本界面: 在上图中,左侧为产品的整个树形图 目前产品有4种状态: 1.普通产品,颜色为黑色 2.需要拼版的产品,颜色为绿色 3.拼版的产品(例如印刷件),基准件为红色 4.拼版的产品,非基准件 ...

  9. python----运行机制

    Python 是一门解释型的编程语言,因此它具有解释型语言的运行机制. 计算机程序,其实就是一组计算机指令集,能真正驱动机器运行的是机器指令,但让普通开发者直接编写机器指令是不现实的,因此就出现了计算 ...

  10. Gitlab之版本回滚

    gitlab提交错误需要回滚版本 首先查看log找到需要回滚的head git log 回滚 git reset --hard 297ff2dcf20605297684f296a4b4ccaa1cf4 ...