HTML5 ES6 语法基础
// 解构赋值 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 语法基础的更多相关文章
- 一些基础的ES6 语法
<script> window.onload = function () { //---------------------------let----------------------- ...
- 把JavaScript代码改成ES6语法不完全指南
目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变 ...
- ES6语法知识
let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的 ...
- 读书笔记(06) - 语法基础 - JavaScript高级程序设计
写在开头 本篇是小红书笔记的第六篇,也许你会奇怪第六篇笔记才写语法基础,笔者是不是穿越了. 答案当然是没有,笔者在此分享自己的阅读心得,不少人翻书都是从头开始,结果永远就只在前几章. 对此,笔者换了随 ...
- 在Node中使用ES6语法
Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把E ...
- WebStorm ES6 语法支持设置
ECMAScript 6是JavaScript语言的下一代标准,已经在2015年6月正式发布了.Mozilla公司将在这个标准的基础上,推出JavaScript 2.0.ES6的目标,是使得JavaS ...
- es6常用基础合集
es6常用基础合集 在实际开发中,ES6已经非常普及了.掌握ES6的知识变成了一种必须.尽管我们在使用时仍然需要经过babel编译. ES6彻底改变了前端的编码风格,可以说对于前端的影响非常巨大.值得 ...
- WebStorm ES6 语法支持设置和ES6语法的JS文件编译为ES5语法文件
ECMAScript 6是JavaScript语言的下一代标准,已经在2015年6月正式发布了.Mozilla公司将在这个标准的基础上,推出JavaScript 2.0.ES6的目标,是使得JavaS ...
- TypeScript语法基础
什么是TypeScript? TypeScript是微软开发的一门编程语言,它是JavaScript的超集,即它基于JavaScript,拓展了JavaScript的语法,遵循ECMAScript规范 ...
随机推荐
- bitset与取数凑数类问题
bitset是C++中的一个东西,定义在头文件#include<bitset>里 所以可以使用#include<bitset>解决取数类的问题https://www.nowco ...
- js实现表格行的动态加入------Day56
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/marSmile_tbo/article/details/36752655 现代页面通常都是用div+ ...
- windows下,java环境变量的设置,设置点击startup.bat启动tomcat
1.首先.安装好java jdk以后环境变量设置: CLASSPATH:.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar JAVA_HOME:C:\ ...
- 如何安装Genymotion模拟器
我们在进行App测试的时候,除了使用真机进行测试,有时候还需要借助模拟器来进行测试,那么Android SDK本身给我们提供了一个原生态的模拟器,但是由于启动太慢,性能太差,逐渐被大家放弃了,那么还有 ...
- 【转】每天一个linux命令(56):netstat命令
原文网址:http://www.cnblogs.com/peida/archive/2013/03/08/2949194.html netstat命令用于显示与IP.TCP.UDP和ICMP协议相关的 ...
- spring 概念之:IoC(控制反转)
IoC(控制反转,Inverse of Control) IoC 的字面意思是控制反转,它包括两方面的内容: 控制 反转 那到底是什么东西的"控制"被"反转"了 ...
- ADO.NET EF 中的实体修改方法
http://www.cnblogs.com/zfz15011/archive/2010/05/30/1747486.html 1.传统修改模式,看下列代码 using (NorthwindEntit ...
- 如何手动关闭tomcat服务,不在Eclipse中的server里按那个红色按钮关
首先,找到Tomcat服务器的安装目录bin目录下的shutdown.bat.然后拖动到命令行进行操作,将Tomcat服务器关闭~ 将shutdown.bat 文件拖至命令行操作当中,执行该命令,即可 ...
- bzoj1066 蜥蜴
Description 在一个r行c列的网格地图中有一些高度不同的石柱,一些石柱上站着一些蜥蜴,你的任务是让尽量多的蜥蜴逃到边界外. 每行每列中相邻石柱的距离为1,蜥蜴的跳跃距离是d,即蜥蜴可以跳到平 ...
- 廖雪峰Java1-2Java程序基础-2变量和数据类型
1.变量 变量是可以持有某个基本类型的数值,或者指向某个对象. 变量必须先定义后使用 定义: 变量类型 变量名 = 初始值; 2.java基本数据类型 整数类型:long int short byte ...