let 与 const

// 并非真正的常量
// const 的本质: const 定义的变量并非常量,并非不可变,
// 它定义了一个常量引用一个值。使用 const 定义的对象或者数组,其实是可变的。
// 下面的代码并不会报错: // 创建常量对象
const car = {type:"Fiat", model:"500", color:"white"};
// 修改属性:
car.color = "red";
// 添加属性
car.owner = "Johnson"; // 创建常量数组
const cars = ["Saab", "Volvo", "BMW"];
// 修改元素
cars[0] = "Toyota";
// 添加元素
cars.push("Audi");

结构赋值

{ // 变量值交换 在之前我们得使用一个中间变量来存储
let a = 1;
let b = 2;
[a, b] = [b, a];
console.log(a, b); // 2 1
} {
function f(){ // 取出函数返回的两个值 例如: 商品单价 商品数量
return [1, 2]
}
let a, b
[a, b] = f()
console.log(a, b) // 1 2
} {
function f() { // 返回多个值时 选择性的接受某几个变量 忽略不想要的
return [1, 2, 3, 4, 5]
}
let a, b, c;
[a, , , b] = f()
console.log(a, b); //1 4
} {
function f() {
return [1, 2, 3, 4, 5]
}
let a, b, c;
[a, , , ...b] = f()
console.log(a, b); //1 [4, 5]
}

字符串的扩展

{
let str = '\u{20bb7}abc'
for (let i = 0; i < str.length; i++) {
console.log(str[i]) // � � a b c
} for(let code of str){
console.log(code) // ? a b c
}
}

对象的扩展

{
// 新增API
console.log('字符串', Object.is('abc', 'abc'), 'abc' === 'abc'); // 字符串 true true
console.log('数组', Object.is([], []), [] === []); // 数组 false false
console.log('拷贝', Object.assign({a: 'a'}, {b: 'b'})); // 浅拷贝 拷贝 {a: "a", b: "b"}
}

目前,ES7有一个提案,引入了跟Object.keys配套的Object.values和Object.entries。ES7兼容插件 import 'babel-polyfill';

symbol

{
let a1 = Symbol.for('abc')
let obj = {
[a1]: '123',
'abc': 345,
'c': 456
}
console.log('obj', obj); // obj {abc: 345, c: 456, Symbol(abc): "123"}
for(let i in obj){ //循环不到Symbol
console.log(i); // abc c
}
console.log(Object.getOwnPropertySymbols(obj)); // [Symbol(abc)]
Object.getOwnPropertySymbols(obj).forEach(item => {
console.log(obj[item]); // 123
})
Reflect.ownKeys(obj).forEach(item => {
console.log(item, obj[item]); // abc 345 c 456 Symbol(abc) "123"
})
}

set和map数据结构

set

 { // 数组去重
let list = [2, 3, 5, 4, 5, '2', 2]
let list2 = new Set(list)
console.log(list2); // Set(5) {2, 3, 5, 4, "2"}
}

{ // 增删清查
let arr = ['add', 'delete', 'clear', 'has']
let list = new Set(arr) console.log('has', list.has('add'), list.entries());
// has true SetIterator {"add", "delete", "clear", "has"} console.log('delete', list.delete('delete'), list.entries());
// delete true SetIterator {"add", "clear", "has"} console.log('clear', list.clear('clear'), list.entries());
// clear undefined SetIterator {} console.log('add', list.add('add'), list.entries());
// add Set(1) {"add"} SetIterator {"add"}
}

WeakSet

  • WeakSet结构与Set类似,也是不重复的值的集合。但是,它与Set有两个区别。

    • 首先,WeakSet的成员只能是对象,而不能是其他类型的值。
    • 其次,WeakSet中的对象都是弱引用,即垃圾回收机制不考虑WeakSet对该对象的引用,也就是说,如果其他对象都不再引用该对象,那么垃圾回收机制会自动回收该对象所占用的内存,不考虑该对象还存在于WeakSet之中。这个特点意味着,无法引用WeakSet的成员,因此WeakSet是不可遍历的。

map

{ // 删清查
let map = new Map([
['a', 123],
['b', 456]
])
console.log('map', map); // map Map(2) {"a" => 123, "b" => 456}
console.log('size', map.size); // size 2
console.log('delete', map.delete('a'), map); // delete true Map(1) {"b" => 456}
console.log('clear', map.clear(), map); // clear undefined Map(0) {}
}

WeakMap

{
let weakmap = new WeakMap() let o = {}
weakmap.set(o, 123)
console.log(weakmap); // WeakMap {{…} => 123}__proto__: WeakMap[[Entries]]: Array(0)length: 0
}

map-set与数组和对象的比较

Proxy 和 Reflect

{ // 代理校验
function validator(target, validator) {
return new Proxy(target, {
_validator: validator,
set(target, key, value, proxy) {
if (target.hasOwnProperty(key)) {
let va = this._validator[key]
if (!!va(value)) {
return Reflect.set(target, key, value, proxy)
} else {
throw Error(`不能设置${key}到${value}`)
}
} else {
throw Error(`${key}不存在`)
}
}
})
} const personValidators = {
name(val) {
return typeof val === 'string'
},
age(val) {
return typeof val === 'number' && val > 18
}
} class Person {
constructor(name, age) {
this.name = name
this.age = age
return validator(this, personValidators)
}
} const person = new Person('lilei', 30)
console.info(person)
// person.name = 48 //报错: 不能设置name到48
// person.sex = '男' // sex不存在
person.name = 'han meimei'
console.info(person) // Proxy {name: "lilei", age: 30}
}

class

{
// 基本定义和生成实例
class Parent {
constructor(name = 'zhangsan') {
this.name = name
}
}
let v_parent = new Parent('v')
console.log('构造函数和实例', v_parent) // 构造函数和实例 Parent {name: "v"}
} {
// 继承
class Parent {
constructor(name = 'lisi') {
this.name = name
}
}
class Child extends Parent {
constructor(name = 'child') {
// this.type = 'child' // 报错
super(name) // 子类想父类传递参数
this.type = 'child'
}
} console.log('继承', new Child) // 继承 Child {name: "child", type: "child"}
} {
// getter, setter
class Parent {
constructor(name = 'wanger') {
this.name = name
}
get longName() {
return 'mk' + this.name
}
set longName(value) {
this.name = value
} }
let v = new Parent()
console.log('getter', v.longName) // getter mkwanger
v.longName = 'hello'
console.log('setter', v.longName) // setter mkhello
} {
// 静态方法
class Parent {
constructor(name = 'zhaowu') {
this.name = name
}
static tell() {
console.log('tell')
}
} Parent.tell() // tell
} {
// 静态属性
class Parent{
constructor(name = 'sunshangxiang'){
this.name = name
}
static tell (){
console.log('tell')
}
}
Parent.type = 'test'
console.log('静态属性', Parent.type) // 静态属性 test
}

promise对象

{
// 所有图片加载完再添加到页面
function loadImg(src) {
return new Promise(function (resolve, reject) {
let img = document.createElement('img')
img.src = src
img.onload = function () {
resolve(img)
}
img.onerror = function (err) {
reject(err)
}
})
} function showImgs(imgs) {
imgs.forEach(img => {
document.body.appendChild(img)
});
}
Promise.all([ // 所有图片加载完后执行
loadImg('http://pic37.nipic.com/20140113/8800276_184927469000_2.png'),
loadImg('http://pic37.nipic.com/20140113/8800276_184927469000_2.png'),
loadImg('http://pic37.nipic.com/20140113/8800276_184927469000_2.png')
]).then(showImgs)
}
{
// 多个图片服务器, 加载最快的一个
// 有一个图片加载完成就添加到页面
function loadImg(src) {
return new Promise((resolve, reject) => {
let img = document.createElement('img')
img.src = src
img.onload = function () {
resolve(img)
}
img.onerror = function () {
reject(err)
}
})
}
function showImg(img){
document.body.appendChild(img)
} Promise.race([ // 谁先请求到 就显示谁
loadImg('http://img2.imgtn.bdimg.com/it/u=234634259,4236876085&fm=26&gp=0.jpg'),
loadImg('http://img4.imgtn.bdimg.com/it/u=2153937626,1074119156&fm=26&gp=0.jpg'),
loadImg('http://img1.imgtn.bdimg.com/it/u=1483033257,4287748004&fm=26&gp=0.jpg')
]).then(showImg)
}

修饰器

{
// 函数属性为只读 /**
* 修饰器基本用法
* 1 修饰器是一个函数
* 2 修改的行为
* 3 修改类的行为
*/
let readonly = function (target, name, descriptor) {
descriptor.writable = false
return descriptor
} class Test {
@readonly
time() {
return '2019-0526'
}
}
let test = new Test() test.time = function () {
console.log('rest time')
}
console.log(test.time())
// cannot assign to read only property 'time' of object '#<Test>'
}

第三方库修饰器的js库: core-decorators

ES6重度学习 demo实例的更多相关文章

  1. 【xxl-job】轻松实现分布式定时任务demo实例

    [项目描述]前段时间专门独立了一个spring boot服务,用于做和第三方erp系统的对接工作.此服务的第一个需求工作就是可以通过不同的规则,设置不同的定时任务,从而获取erp系统的商品数据.所以, ...

  2. 【java】之 apache commons-codec 与Apache Digest demo实例,支持md5 sha1 base64 hmac urlencode

    使用commons-codec 进行加密的一些操作 package com.jiepu.ApacheDigest; import java.io.FileInputStream; import org ...

  3. SQL语句学习手册实例版

    SQL语句学习手册实例版 表操作 例1  对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE  TABLE  STUDENTS (SNO      NUMERIC (6, ...

  4. TCP/IP协议学习之实例ping命令学习笔记

    TCP/IP协议学习之实例ping命令学习笔记(一) 一. 目的为了让网络协议学习更有效果,在真实网络上进行ping命令前相关知识的学习,暂时不管DNS,在内网中,进行2台主机间的ping命令的整个详 ...

  5. 移动端页面弹幕小Demo实例说明

    代码地址如下:http://www.demodashi.com/demo/11595.html 弹幕小Demo实例地址,点击看效果 写在前面:尝试做了一下弹幕的实例,欢迎提出并指正问题 问题说明: D ...

  6. jetty demo实例启动

    Jetty是一个提供HHTP服务器.HTTP客户端和javax.servlet容器的开源项目.Jetty和tomcat相比,是轻量级服务器,支持热拔插,可扩展性大tomcat集成了很多功能,个性化瘦身 ...

  7. react目录结构、demo实例详解、属性数据绑定方式

    1.目录结构 2.demo实例详解 a)创建Home.js import React, { Component } from 'react'; //创建一个组件必须要集成Component组件,且组件 ...

  8. Thymeleaf 学习笔记-实例demo(中文教程)

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

  9. RPC框架学习+小Demo实例

    一.什么是RPC协议? 全称:远程过程调度协议 效果:使消费者向调用本地方法一样调用远程服务方法,对使用者透明 目前常用:Dubbo.Thirft.Sofa.... 功能: 建立远程通信(socket ...

随机推荐

  1. [PyTorch 学习笔记] 1.1 PyTorch 简介与安装

    PyTorch 的诞生 2017 年 1 月,FAIR(Facebook AI Research)发布了 PyTorch.PyTorch 是在 Torch 基础上用 python 语言重新打造的一款深 ...

  2. Centos7查看端口占用

    (1)netstat -lnp|grep 50090 如果提示没有netstat命令,可需要安装:yum -y install net-tools (2) lsof -i:50090 参考链接:lin ...

  3. TS流解码过程-ES-PES-PTS-DTS

    转载自http://blog.chinaunix.net/uid-9688646-id-1998407.html TS 流解码过程: 1. 获取TS中的PAT 2. 获取TS中的PMT 3. 根据PM ...

  4. sge的简单的应用

    1.sge提交脚本qsub 1.qsub work.sh work.sh 不能以数字开头 2.qsub work.sh  默认工作路径为/home/username 3.qsub -cwd work. ...

  5. 解决使用git,ssh每次都要输入密码

    建议:生成ssh 公钥私钥的时候,不要输入密码. 解决方案: 1.修改密码:使用命令 ssh-keygen -p 然后修改密码的时候直接回车,也就是把密码置空. 2.重新生成ssh key, 用 ss ...

  6. Reinforcement learning in artificial and biological systems

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! Abstract 在生物和人工系统的学习研究之间,已经有富有成果的概念和想法流.Bush and Mosteller,Rescorla a ...

  7. ReplayingDecoder 解码器:别以为我有多厉害,也只不过是使用了一下装饰器模式而已~

    原文地址 一.设计模式为啥老是用不好? 想要写出更屌的代码,提高代码的健壮性和可扩展性,那么设计模式可谓是必学的技能. 关于学习设计模式,大家可能都觉得设计模式的概念太过于抽象,理解起来有点费劲:又或 ...

  8. formily-面向中后台场景的复杂解决方案

    正文 在解决企业级应用的前端问题中,表单是个无法绕过的大山,正好最近有时间,调研一下 Formily-来自阿里巴巴的面向中后台复杂场景的表单解决方案,也是一个表单框架,前身是 UForm.主要解决如何 ...

  9. AD18 PCB中添加中文字符串显示乱码问题解决

    该问题是由于字符串的自体类型设置问题,AD默认是[stroke],我们点击[TrueType]即可正常显示.PS:AD18搞啥呢,默认显示输入内容不行吗,找半天!!!

  10. python给excel文件加密码,并重新生成文件

    需安装pywin32 pip install pywin32 直接上源码.简单几行就搞定 很多人学习python,不知道从何学起.很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手. ...