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规范 ...
随机推荐
- 浏览器中的data类型的Url格式,data:image/png,data:image/jpeg!(源自:http://blog.csdn.net/roadmore/article/details/38498719)
所谓"data"类型的Url格式,是在RFC2397中 提出的,目的对于一些“小”的数据,可以在网页中直接嵌入,而不是从外部文件载入.例如对于img这个Tag,哪怕这个图片非常非常 ...
- 【NOI2003】银河英雄传
迭代不一定比递归好 原题: 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星 ...
- 黑电-逻辑地址-0X4EB9FDE3- %o %d %x
****************************************************************************** 编程语言通常规定是以0开头的数字是八进制数 ...
- dockercompose up build fail
docker https://auth.docker.io/token dial tcp lookup auth.docker.io i/o timeo Error response from dae ...
- graphql elasticsearch 集成试用
graphql 是很方便的api 查询语言,elasticsearch 可以方便的进行全文检索的应用开发 有一个方便的npm 包graphql-compose-elasticsearch 可以进行es ...
- nyoj 某种序列
某种序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 数列A满足An = An-1 + An-2 + An-3, n >= 3 编写程序,给定A0, A1 ...
- FP-growth算法发现频繁项集(一)——构建FP树
常见的挖掘频繁项集算法有两类,一类是Apriori算法,另一类是FP-growth.Apriori通过不断的构造候选集.筛选候选集挖掘出频繁项集,需要多次扫描原始数据,当原始数据较大时,磁盘I/O次数 ...
- 【转】每天一个linux命令(37):date命令
原文网址:http://www.cnblogs.com/peida/archive/2012/12/13/2815687.html 在linux环境中,不管是编程还是其他维护,时间是必不可少的,也经常 ...
- 【转】每天一个linux命令(13):less 命令
原文网址:http://www.cnblogs.com/peida/archive/2012/11/05/2754477.html less 工具也是对文件或其它输出进行分页显示的工具,应该说是lin ...
- vue 知识点
Vue 中的 slot: 概念:槽/slot是组件在模板中为调用者预留的位置,使用<slot>元素声明一个 槽.在最终的视图中,调用者模板中被调用组件的内容,将填充<slot> ...