// 解构赋值
let [a, b, c, [s,e],d] = ["aa", "bb", "cc", [12, 23], "dd"];
console.log(s);

// 结构方法
add({add1: 12, add2: 13})
function add({add1, add2}) {
    console.log(add1 + add2);
}

// 唯一值
let aa = Symbol(3);
let bb = 3;
console.log(aa == bb)

// 值唯一的伪数组 SET 对象 遍历方式 for...of
let set = new Set([1,2,2,2,4,4]);
for (let elem of set) {
    console.log(elem)
}

// 值唯一的伪数组 SET 对象 赋值方法 1
let set = new Set();
for (let i = 0; i < 5; i++) {
    set.add(i);
}

// 循环遍历数组的方法 Map
let set = new Set();
[1,2,3,45,5,5].map(function (elem) {
    console.log(elem);
})

// 将 SET 对象转化为 数组的方式
let set = new Set([1,2,2,2,4,4]);
console.log(set);
console.log([...set]);

// SET 对象的 清空 和 删除
let set = new Set([1,2,2,2,4,4]);
set.delete(2);
console.log([...set]);
set.clear();
console.log([...set]);

// 判断 SET 对象是否存在某个值, 以及获取 元素 的数量
let set = new Set([1,2,2,2,4,4]);
console.log(set.has(2));
console.log(set.has(5));
console.log(set.size);

// 数组的 遍历循环操作 map 和 数组过滤器 filter
let arr = [1,2,3,4,5,6,5];
let arrs = arr.map(function (value) {
    return value * 2;
})
let arrss = arrs.filter(function (value) {
    return value == 10;
});
console.log(arrs)
console.log(arrss)

// 数组遍历 forEach
let arr = [1,2,3,4,5,6,5];
arr.forEach(function (value, key) {
    console.log(key + " = " + value);
})

// 元素必须是对象的 SET 对象 WeakSet ( 所拥有的方法和 set 相似 )
let weakSet = new WeakSet();
weakSet.add(new Number(5));

// 数据结构 Map, 本质上是二位数组, ( API => 元素是否存在 has 删除 delete)
let map = new Map();
map.set("nihao", "buhao");
console.log(map.get("nihao"));

// WeakMap 对象做值 对象做键 基本没用
let weakMap = new WeakMap();

// 数组和伪数组的 遍历器 Iterator 性能比常规循环遍历 性能高
let arr = ["你好", 1, 45, "不知道", true];
let it = arr[Symbol.iterator]();
for(let i = it.next(); !i.done; i = it.next()) {
    console.log(i.value);
}

// Generator 函数 异步编程方案 1
function *myGenerator() {
    console.log(1);
    yield 2;
    console.log(3)
    yield 4;
    return "end";
}
let y = myGenerator();
console.log(y.next());
console.log(y.next());
console.log(y.next());
console.log(y.next());

// Promise 对象 异步编程方案 2
new Promise(function (resolve, reject) {
    setTimeout(function () {
        console.log(3000)
        resolve();
    }, 3000);
}).then(function () {
    new Promise(function () {
        setTimeout(function () {
            console.log(3000)
        }, 3000);
    })
});

// Async 函数 异步编程方式 3
(async function () {
    setTimeout(function () {
        console.log(111)
    }, 2000)
})().then(async function () {
    setTimeout(function () {
        console.log(111)
    }, 2000)
});

// 箭头函数
let fun = (c = 3) => {
    console.log(c);
}
fun();

// Proxy 代理, 可以拦截的方法比较多, 但是兼容性欠缺
class A {}
let a = new A();
let p = new Proxy(a, {
    get: function (target, key) {
        console.log ("调用 GET 方法");
        return target[key];
    },
    set: function (target, key, value) {
        console.log("调用 SET 方法");
        return Reflect.set(target, key, value);
    }
});
p.id = 3;
console.log(p.id)

// Decorator 修饰器 装饰模式; 只能修饰类和类的方法
function choose (target) {
    target.course = "物理";
}
@choose
class Student {}
console.log(Student.course)

HTML5 ES6 语法基础的更多相关文章

  1. 一些基础的ES6 语法

    <script> window.onload = function () { //---------------------------let----------------------- ...

  2. 把JavaScript代码改成ES6语法不完全指南

    目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...

  3. ES6语法知识

    let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的 ...

  4. 读书笔记(06) - 语法基础 - JavaScript高级程序设计

    写在开头 本篇是小红书笔记的第六篇,也许你会奇怪第六篇笔记才写语法基础,笔者是不是穿越了. 答案当然是没有,笔者在此分享自己的阅读心得,不少人翻书都是从头开始,结果永远就只在前几章. 对此,笔者换了随 ...

  5. 在Node中使用ES6语法

    Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把E ...

  6. WebStorm ES6 语法支持设置

    ECMAScript 6是JavaScript语言的下一代标准,已经在2015年6月正式发布了.Mozilla公司将在这个标准的基础上,推出JavaScript 2.0.ES6的目标,是使得JavaS ...

  7. es6常用基础合集

    es6常用基础合集 在实际开发中,ES6已经非常普及了.掌握ES6的知识变成了一种必须.尽管我们在使用时仍然需要经过babel编译. ES6彻底改变了前端的编码风格,可以说对于前端的影响非常巨大.值得 ...

  8. WebStorm ES6 语法支持设置和ES6语法的JS文件编译为ES5语法文件

    ECMAScript 6是JavaScript语言的下一代标准,已经在2015年6月正式发布了.Mozilla公司将在这个标准的基础上,推出JavaScript 2.0.ES6的目标,是使得JavaS ...

  9. TypeScript语法基础

    什么是TypeScript? TypeScript是微软开发的一门编程语言,它是JavaScript的超集,即它基于JavaScript,拓展了JavaScript的语法,遵循ECMAScript规范 ...

随机推荐

  1. 《DSP using MATLAB》Problem 4.20

    代码: %% ------------------------------------------------------------------------ %% Output Info about ...

  2. 结构体:HASH表模板

    这种 HASHMAP 就是一个链式前向星的表: 其中: init 函数:hashmap 创建初始化: check 函数:寻找 hash 表中是否有需要查找的值,若有则返回 1 ,否则返回 0 :遍历方 ...

  3. 清华集训2016Day4

    清华集训2016Day4 组合数问题(problem) 用卢卡斯定理可知满足条件即将\(n\)和\(m\)分别用\(k\)进制表示,要求\(n\)的每一位都要大于等于\(m\)的对应位.直接数位\(d ...

  4. setsebool命令详解与SELinux管理

    setsebool命令是用来修改SElinux策略内各项规则的布尔值.setsebool命令和getsebool命令是SELinux修改和查询布尔值的一套工具组.SELinux的策略与规则管理相关命令 ...

  5. 【BZOJ3110】【Zjoi2013】K大数查询 - 2

    之前用权值线段树套区间线段树水过,现在再练习一下整体二分 原题:有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c如果是2 a b ...

  6. log4net保存到数据库系列二:独立配置文件中配置log4net

    园子里面有很多关于log4net保存到数据库的帖子,但是要动手操作还是比较不易,从头开始学习log4net数据库日志一.WebConfig中配置log4net 一.WebConfig中配置log4ne ...

  7. SQL 存储过程入门(五)

    好久没来博客园留下点东西,忙到找工作,最近把工作落实了. 最近公司的业务都是存储过程开发,发现去维护起来相当困难. 由于是维护项目,产品很久前都发布了,然而有一些修改,让我们去修改现在的逻辑,去看懂人 ...

  8. Javascript 在严格模式下禁止指向 this

    如下代码, f() 输出的是 false,而 f2() 输出的是 true. 这是因为 f2 在严格模式下禁止 this 指向全局,所以 this 是 undefined, !this 当然是 tru ...

  9. python Django Nginx+ uWSGI 安装配置

    环境: CentOS7.python-3.5.3.Nignx 1.10.3 .Django 1.10.6.uWSGI 2.0.14 django项目目录:/var/webRoot/p1 项目结构: 基 ...

  10. JZ2440 裸机驱动 第7章 内存管理单元MMU

    本章目标:     了解虚拟地址和物理地址的关系:     掌握如何通过设置MMU来控制虚拟地址到物理地址的转化:     了解MMU的内存访问权限机制:     了解TLB.Cache.Write ...