ES6常用总结

const

使用const声明的常量必须赋值、赋值后不可再更改
const定义的常量如果是引用类型 可以改变对象内属性

es6中class类

基本使用:
    class Person {
        constructor(name, age) {
            this.name = name;
            this.age = age;
        }

        showName() {
            console.log(this.name)
        }
    }
    var p = new Person('kobe', 39);

继承:
    class Chinese extends Person {
        子类继承父类,若有自己独有的属性和方法,应该重写constructor构造器,
        构造器中应传入父类公共的属性,将 super()函数写入constructor中并位于第一位,
        并将父类属性传入super()函数中,此时 super() 就相当于父类中构造器constructor
     constructor(name, age, IdNumber) {
        super(name, age);
        this.IdNumber = IdNumber;
     }
     showName() {//父类方法重写
            console.log(this.name,this.age,this.grade);
     }
    }
    var p = new Chinese('ss', 12, 45);
    p.showName();
    
可以使用super直接调用父类的方法  super.say();
                class son extends Father {

                  say() {
                    console.log(super.say() + '儿子')
                  }
                }

三点运算符 ...value

函数中使用
function fn(...value) {  value是一个真数组 将参数归为一个数组中
    console.log(value);
    for (var i = 0; i < value.length; i++) {
    console.log(value[i]);
  }
}

fn(1, 30); // 结果:[1, 30]
数组中使用
var arr1=[1,6];
var arr2 = [2,3,4,5];

让arr2插入到arr1中

arr1 = [1,...arr2,6];
console.log(arr1);// 1 2 3 4 5 6

var arr=[1,2,3];
console.log(...item) 1   2    3

导入、导出

export const num = 'xxx'
export function...
export default ....
import {} from 'xxx'
import xxx from 'xxx'

形参默认值

function Point(x = 0, y = 0) {
    this.x = x;
    this.y = y;
}

var p1 = new Point(10, 20);
console.log(p1); // Point {x: 10, y: 20}

var p2 = new Point();
console.log(p2);// Point {x: 0, y: 0}

字符串扩展

var str = 'ab';
console.log(str.includes('b'));//true
console.log(str.startsWith('a'));//true
console.log(str.endsWith('b'));//true
console.log(str.repeat(3)); //ababab

数值扩展

------、数值扩展

Number.isFinite() -- 是否是有限数
console.log(Number.isFinite(123));//true
console.log(Number.isFinite(Infinity));//false

Number.isNaN()--是否是非数字
console.log(Number.isNaN(123));//false
console.log(Number.isNaN(NaN));//true
Number.isInteger()--是否是整数
console.log(Number.isInteger(123));//true
console.log(Number.isInteger(123.56));//false
Number.parseInt()--将字符串转换为整数
console.log(Number.parseInt('123.abs'));//123
Math.trunc()--直接去除小数部分
console.log(Math.trunc(343.56));//343



数组扩展

Array.from()//将伪数组转为真数组
Array.of(v1,v2,v3)//将一系列数值转为数组
[].find(function( item ,index ){ return item > 4; });//找出第一个满足条件返回true的数值
[].findIndex(function( item ,index ){ return item > 4; });//找出第一个满足条件返回true的数值的下标

对象扩展

console.log(0 == -0 );//true
console.log(NaN == NaN );//false NaN与任何数都不相等
Object.is(s1,s2);//判断两个对象是否相等 以字符串为标准判断的
    Object.is( 0 , -0) ;//false
    Object.is( NaN , NaN);//true
Object.assign(目标对象, 源对象, 源对象,源对象...);//将源对象的属性复制到目标对象上

直接操作__proto__属性
    var obj1 = {};
    var obj2 = {grade: 5};
    obj1.__proto__ = obj2;
    console.log(obj1.grade);//5

Promise

基本使用
Promise是ES6提供的一种处理异步编程的对象 目的是以一种优雅的方式解决回调地狱
有了promise对象,可以将异步操作以同步的流程表达出来,
避免层层嵌套的回调地狱 Promise是一个构造函数 通过实例化方式使用
    示例:
    const p = new Promise((resolve,reject)=>{
     setTimeOut(()=>{
         if..
           resolve('成功');
         else..
            reject('失败');
     },3000)
    });
    p.then((data)=>{},err=>{})
(promise会立即执行 应该将其放在方法中)
多层嵌套
new Promise((resolve, reject) => {
  resolve('aaa');
  // reject('失败了')
}).then((data) => {
  console.log(data + '第一层处理结果')
  return new Promise((resolve, reject) => {
    resolve(data + '第二层请求');
  })
}).then((data) => {
  console.log(data)

  return new Promise((resolve, reject) => {
    resolve(data + '第三层');
  })
}).then((data) => {
  console.log(data)
}).catch(() => {
  console.log('错误回调')
})
同时处理多次异步请求
Promise.all([
  new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve('11')
    }, 1000)
  }),
  new Promise((resolve) => {
    setTimeout(() => {
      resolve('22')
    }, 2000)
  })
]).then((results) => {
  console.log(results)
})

set、map

https://blog.csdn.net/zm17671443092/article/details/108586989
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容

  • 新增的常用特性: 1、Let 和Const2、模板字符串 3、对象属性缩写 4、箭头函数5、新增的对象操作方法 6...
    surlyyoung阅读 853评论 0 0
  • 简介 ES6, 全称 ECMAScript 6.0 ,是 JavaScript 的下一个版本标准,2015.06 ...
    Nicander阅读 246评论 0 1
  • 一 let和const 1.let (1)一个大括号就是一个块级作用域,let声明的变量只在自己作用域有效; (2...
    37883932bb4d阅读 359评论 0 1
  • ES5 1、严格模式 *理解 1、除了正常运行的模式(混杂模式),es5添...
    Shy啊阅读 2,397评论 0 1
  • 1.let命令 ①let声明的变量只在它所在的代码块有效。 ②使用let声明变量时for循环设置循环变量的...
    慕名66阅读 288评论 0 0