zoukankan      html  css  js  c++  java
  • es6 类

    1. es5 类写法

        function People(name) {
          this.name = name;
        }
        People.prototype.getName = function () {
          return this.name;
        };
        var people = new People("strick");
        console.log(people.getName());
    View Code
    static a = 20;  // 等同于 Person.a = 20

    继承 extends
    class Student extends Person {}
    继承的构造函数中,我们必须如上面的例子那么调用一次super方法,它表示构造函数的继承,与ES5中利用call/apply继承构造函数是一样的功能。

    2. es6 类写法

        class People {
          constructor(name) {
            this.name = name;
          }
          getName() {
            return this.name;
          }
        }
    View Code

    3. es6 类相关概念

    3.1 表达式

        var People = class Man {
          getSelf() {
            console.log(typeof Man); //"function"
            console.log(Man.name); //"Man"
            console.log(new Man().getAge()); //28
            return 'hello';
          }
          getAge() {
            return 28;
          }
        };
        var people = new People();
        console.log(people.getSelf());
        console.log(People.name); //"Man"
        console.log(Man.name); //Man未定义的错误
    View Code

    3.2 立即执行

        var people = new class {
          constructor(name) {  
            this.name = name;
          };
          getName() {
            return this.name;
          };      
        }("strick");
        console.log(people.getName()); //"strick"
    View Code

    3.3 自有属性

    class People {
      constructor() {
        this.name = "strick";
      }
    }
    View Code

    3.4 访问器属性

        class People {
          get prop() {
            return `getter:${this.name}`;
          }
          set prop(value) {
            this.name = value;
          }
        }
        var people = new People();
        people.prop = "strick";
        console.log(people.prop); // getter:strick
    View Code

    3.5 计算成员名

        var method = "getAge";
        class People {
          ["get" + "Name"]() {
            return "strick";
          }
          [method]() {
            return 28;
          }
        }
        var people = new People();
        console.log(people.getName()); //"strick"
        console.log(people.getAge()); //28
    View Code

    3.6 生成器

        class People {
          * getName() {
            yield "strick";
          }
        }
        var people = new People(),
          iterator = people.getName();
        console.log(iterator.next()); //{value: "strick", done: false}
    View Code

    3.7 静态方法

        class People {
          static getName() {
            return "strick";
          }
          getName2() {
            return "strick";
          }
        }
        var people=new People();
        console.log(people.getName2());
    View Code
  • 相关阅读:
    题解 P2296 【寻找道路】
    题解 CF534C 【Polycarpus' Dice】
    题解 CF294B 【Shaass and Bookshelf】
    题解 SP4354 【TWINSNOW Snowflakes】
    题解 UVA10294 【Arif in Dhaka (First Love Part 2)】
    FLV文件格式解析部分代码
    关于“无法定位程序输入点getaddrinfo于动态链接库WS32_32.dll上”的问题
    MinGW介绍与使用
    FFMPEG: 0.4.9
    可以处理UTF8编码的md5函数
  • 原文地址:https://www.cnblogs.com/justSmile2/p/10712016.html
Copyright © 2011-2022 走看看