es6---变量声明方式

家住魔仙堡 提交于 2020-03-22 16:57:26

1. 声明一个变量有多少种方式

 var, function, let, const, import, class

2. let, const

  • a. 块作用域 (es6引入了块级作用域,所以let、const在自己所在的代码块有效
  • b. 不存在变量的提升,且存在死区
  • c. 不可以重复声明
  • d. const不变的指针,指针里面的内容可变

3. 变量的解构


 

let

1. let只在所在的代码块中有效

2. 以前我们需要用IIFE解决的问题  https://blog.csdn.net/u013746071/article/details/80595596

3. 不存在变量声明提升

4. 暂时性死区TDZ
        //1. let只在所在的代码块中有效
        for (var i = 0; i < 10; i++) { }
        console.log(i); //10

        for (let j = 0; j < 10; j++) { }
        console.log(j); //// Error: j is not define

 

console: 

 

 

 

        //2. 以前我们需要用IIFE解决的问题
        for (var i = 0; i < 5; i++) {
            setTimeout(() => {
                console.log(i);//输出5次5
            }, 0);
        }

        for (var k = 0; k < 5; k++) {
            (function (k) {
                setTimeout(() => {
                    console.log(k);//输出0,1,2,3,4
                }, 0);
            })(k);
        }

        for (let j = 0; j < 5; j++) {
            setTimeout(() => {
                console.log(j);//输出0,1,2,3,4
            }, 0);
        }

 

console:

 

        //3. 不存在变量声明提升
        console.log(foo);// 输出undefined
        console.log(bar);// 报错ReferenceError

        var foo = 2;
        let bar = 2;

 

console:

 

        //4. 暂时性死区TDZ
        var temp = 123;
        if (true) {
            //TDZ start
            temp = "abc";//ReferenceError
            console.log(temp);//ReferenceError
            //TDZ end
            let temp;
            console.log(temp);//undefined

            temp = 12;
            console.log(temp);//12
        }

 

        //5. let不允许重复声明
        {
            let a = 1;
            let a = 10;//报错
        }

 

 

Const

1. 大部分和let差不多
2. const(只读)(一旦声明必须赋值)
3. 对于复合类型变量(可以给它的属性赋值)
        //1. 大部分和let差不多
        //2. const(只读)(一旦声明必须赋值)
        const MAX = 123;
        MAX = 1; //报错

 

        //3. 对于复合类型变量(可以给他的属性赋值)
        const a = {};
        a.name = "dai";
        a.age = 21;

 

        //4. 如果你不想添加属性
        const b = Object.freeze({});
        b.name = 'dai'; //TypeError

 

es6引入了块级作用域,所以let、const在自己所在的代码块有效

        {
            var b = 1;
            {
                var b = 10;
                console.log(b); //10
            }
            console.log(b); //10

        }

        {
            let a = 1;
            {
                let a = 2;
                console.log(a); //2
            }
            console.log(a); //1
        }

 

 

class

1. class作为es6的语法糖,实际es5也可以实现

        //1. class作为es6的语法糖,实际es5也可以实现
        class Point {
            constructor(x, y) {
                this.x = x;
                this.y = y;
            }
            toString() {
                return this.x + ',' + this.y;
            }
        }
        Object.assign(Point.prototype, {
            getX() {
                return this.x;
            },
            getY() {
                return this.y;
            }
        })

        let p1 = new Point(1, 2);
        console.log(p1.toString());//1,2
        console.log(p1.getX()); //1
        console.log(p1.getY()); //2
        console.log(Object.keys(Point.prototype));// ["getX", "getY"]

(1)、方法之间不需要逗号分隔
(2)、toString () {} 等价于 toString: function () {}
(3)、你仍然可以使用Point.prototype
(4)、你可以用Object.assign()一次性扩展很多方法
(5)、类内部定义方法多是不可以枚举的
(6)、constructor(){}是一个默认方法,如果没有添加,会自动添加一个空的。
(7)、constructor默认返回实例对象(this),完全可以指定返回其他的对象。
(8)、必须用new调用
(9)、不存在变量提升
(10)、当用一个变量去接受class时,可以省略classname
(11)、es6不提供私有方法

  //2、使用extends继承
  class ThreeDPoint extends Point {
    constructor (x, y, z) {
      console.log(new.target); //ThreeDPoint
      super(x, y);
      this.z = z;
    }

    toString () {
      return super.toString() + ',' + this.z;
    }

    static getInfo() {
      console.log('static method');
    }

    get z() {
      return 4;
    }
    set z(value) {
      console.log(value);
    }
  }
  ThreeDPoint.getInfo(); // "static method"
  let ta = new ThreeDPoint(2,3,4);
  console.log(ta.toString()); //2,3,4
  console.log(ta.z); // 4
  ta.z = 200; // 200
  console.log(Object.getPrototypeOf(ThreeDPoint)); //Point

(1)、constructor中必须调用super,因为子类中没有this,必须从父类中继承。
(2)、子类的__proto__属性总是指向父类
(3)、子类的prototype属性的__proto__总是指向父类的prototype
(4)、Object.getPrototypeOf()获取父类
(5)、super作为方法只能在constructor中
(6)、super作为属性指向父类的prototype.
(7)、在constructor中使用super.x = 2,实际上this.x = 2;但是读取super.x时,又变成了父类.prototype.x。
(8)、原生构造函数是无法继承的。
(9)、get set 方法可以对属性的赋值和读取进行拦截
(10)、静态方法不能被实例继承。通过static声明
(11)、静态属性只能 ThreeDPoint.name = "123" 声明 (与static没什么关系)

 

import

1. es6引入自己的模块系统,通过export导出,import导入
2. 与CommonJs不同的是,它是获取模块的引用,到用的时候才会真正的去取值 
 
        //3. 例如student.js中:
        let student = [
            {
                name: '小张',
                age: 20,
            },
            {
                name: '小沈',
                age: 21,
            },
            {
                name: '小朱',
                age: 23,
            }
        ]
        export default student;//// 这种导出方式,你可以在import时指定它的名称

 

        //4. 在app.js中我们可以这样用:
        import StudentList from './student.js'; //指定名称
        console.log(StudentList[0].name);//小张

 

 

 

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!