ES6上

Posted guotianbao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6上相关的知识,希望对你有一定的参考价值。

ES6简介

  1. EMCAScript(ECMA、ES)标准
  2. javascript是EMCAScript的一种

ES6新语法

1.变量、赋值

var 可以重复定义、不能限制修改、没有块级作用域
var 需要封装进function
let 不能重复定义、变量、块级作用域{}
const 不能重复定义、常量、块级作用域{}

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title></title>
    <script>
    window.onload=function (){
      var aBtn=document.getElementsByTagName('input');

      for(var i=0;i<aBtn.length;i++){
        aBtn[i].onclick=function (){
          alert(i);
        };
      }
    };
    </script>
  </head>
  <body>
    <input type="button" value="1">
    <input type="button" value="2">
    <input type="button" value="3">
  </body>
</html>

alert出来的都是3
把alert的内容放到函数中才正常

<script>
window.onload=function (){
  var aBtn=document.getElementsByTagName('input');

  for(var i=0;i<aBtn.length;i++){
    // var 需要函数级作用域包起来
    // let 和 const不用,它们只需要大括号即可
    (function(i){
      aBtn[i].onclick=function (){
        alert(i);
      };
    })(i);
    }
};
</script>
</head>
<body>
<input type="button" value="1">
<input type="button" value="2">
<input type="button" value="3">
</body>

如let则不需要封装进function中

<script>
window.onload=function (){
  let aBtn=document.getElementsByTagName('input');
  // for 循环本身就是语法块
  for(let i=0;i<aBtn.length;i++){
    aBtn[i].onclick=function (){
      alert(i);
    };
  }
};
</script>
</head>
<body>
<input type="button" value="1">
<input type="button" value="2">
<input type="button" value="3">
</body>

解构赋值
1.左右两边必须一样
2.定义和赋值必须同时进行

<script>
window.onload=function (){
  // 给a、b、c分别赋值
  // 两边结构要一样,如同数组、同json等
  let [a,b,c]=[12,13,15];
  let {a,b,c}={a=12,b=13,c=15};
  //粒度
  let [a,b,c]=[12,{b:{f:66},g:12},c=12]
</script>
2.函数
//原来  
function (参数,参数){  
    函数体  
  }  
//箭头函数   
  (参数,参数)=>{  
    函数体  
  }  
  1.如果有且仅有1个参数,()可以省
  2.如果函数体只有一句话,而且是return,{}可以省
  *关于this

  默认参数
    (a, b=xx, c=xx)

  参数展开(剩余参数、数组展开)
  1.“三个点”的第1个用途:接收剩余参数
    function show(a, b, ...args)
    剩余参数必须在参数列表的最后
    function show(a,b,...args){

    }

    def show(a,b,*args,c,d):
    pass

  2.“三个点”的第2个用途:展开一个数组  
3.数组/json
  数组——5种
  map     映射:一个对一个
  let arr=[66,50,78,92,16]
  let arr2=arr.map(item=>item>=60)

  reduce  汇总:一堆->一个
  let arr=[66,50,78,92,16]
  let sum=arr.reduce((tmp,item.index)=>{
    return tmp+item
  });

  filter  过滤:
  let arr=[66,51,78,93,16]
  let arr2=arr.filter(item=>item%2)    

  forEach 遍历:
  let arr=[66,51,78,93,16]
  let sum=0
  arr.forEach(item=>{
    sum+=item
  });

   // 把类数组对象转化成数组,才可以调用forEach进行遍历
  Array.from([array-like])=>[x,x,x]  

json——2变化
    1.简写:名字和值一样的,可以省
        let a=5;
        let b=12;
        json={a:a,b:b}等价于{a,b}
    2.function可以不写
        <script>
        /*let json={
          a: 12,
          b: 5,
          show: function (){
            alert(this.a+this.b);
          }
        };*/
        let json={
          a: 12,
          b: 5,
          show(){
            alert(this.a+this.b);
          }
        };

        json.show();
        </script>
4.字符串

字符串模板:植入变量、任意折行

// 字符串模板 `` 反单引号
let json={name: 'mu', age: 18};
//alert('我叫:'+json.name+',我今年'+json.age+'岁');
alert(`我叫:${json.name},我今年${json.age}岁`);
// 随便换行
/*alert('abc');*/
alert(`ab
  cde
  f
  d`);

if(sNum.startsWith('135')){
  alert('移动');
}else{
  alert('联通');
}

if(filename.endsWith('.txt')){
  alert('文本文件');
}else{
  alert('图片文件');
}
5.面向对象
//传统js对象
function Person(name, age){
  this.name=name;
  this.age=age;
}

//给对象增加函数
Person.prototype.showName=function (){
  alert('我叫'+this.name);
};
Person.prototype.showAge=function (){
  alert('我'+this.age+'岁');
};
let p=new Person('mu',18)
p.showName()
p.showAge()
//--------------------------------------------------
function Worker(name, age, job){
  Person.call(this, name, age);
  this.job=job;
}

Worker.prototype=new Person();
Worker.prototype.constructor=Worker;
Worker.prototype.showJob=function (){
  alert('我是做:'+this.job);
};

let w=new Worker('mu', 18, '打杂的');

w.showName();
w.showAge();
w.showJob();
//------------------------------------------------
// class/constructor
class Person{
  constructor(name, age){
    this.name=name;
    this.age=age;
  }

  showName(){
    alert('我叫'+this.name);
  }
  showAge(){
    alert('我'+this.age+'岁');
  }
}

let p=new Person('mu', 18);
p.showName();
p.showAge();
//---------------------------------------------
// extends/super
class Worker extends Person{
  constructor(name, age, job){
    //super-超类(父类)
    super(name, age);
    this.job=job;
  }

  showJob(){
    alert('我是做:'+this.job);
  }
}

let w=new Worker('mu', 18, '打杂的');
w.showName();
w.showAge();
w.showJob();
//-------------------------------------------
// bind——给函数定死一个this
class Person{
  constructor(name, age){
    this.name=name;
    this.age=age;
  }

  showName(){
    alert(this);
    alert('我叫'+this.name);
  }
  showAge(){
    alert('我'+this.age+'岁');
  }
}
let p=new Person('mu', 18);
document.onclick=p.showName.bind(p);
//----------------------------------------------------
//普通函数:根据调用我的人  this老变  


//----------------------------------------------------
//箭头函数:根据所在的环境  this恒定
// 输出document对象
document.onclick=function (){
  let arr=[1,2,3];

  arr.a=()=>{
    alert(this);
  };

  arr.a();
};  
6.Promise
7.generator
8.async/await
9.模块化 ES6

以上是关于ES6上的主要内容,如果未能解决你的问题,请参考以下文章

es6中class类的全方面理解------继承

ES5和ES6中的继承 图解

phpstorm线上代码同步(转)

打造云上代码交付链_CodePipeline实践分享

数据库事务课上代码

更新github上代码