zoukankan      html  css  js  c++  java
  • JavaScript中class类的介绍

    class的概念

    一、我们为什么要用到class类?

    因为通过class类来创建对象,使得开发者不必写重复的代码,以达到代码复用的目的。它基于的逻辑是,两个或多个对象的结构功能类似,可以抽象出一个模板,

    依照模板复制出多个相似的对象。就像汽车制造商一遍一遍地复用相同的模板来制造大量的汽车车,我们暂且把class理解为一个模板。

    但是为什么我们不用function函数用来重复使用呢?

    因为funcion声明是需要状态提升的,而class不是,class需要先声明再使用。

    二、class类的语法

     1     class Student{
     2         constructor(name,age,sex){
     3             this.name = name
     4             this.age= age
     5             this.sex = sex
     6         }
     7 
     8         read(){console.log(this.name+this.age+this.sex)}
     9     }
    10     var Tom =new Student('tom',21,'男')
    11     Tom.read()

    Tom是通过类Student实例化出来的对象。对象Tom是按照Student这个模板,实例化出来的对象。实例化出来的对象拥有预先定制好的结构和功能。

    2.1 constructor 构造方法

    constructor方法是一个特殊的方法,用来创建并初始化一个对象。在一个class中只能有一个命名为constructor的特殊方法,如果包含多个将会报错。

    constructor中可以通过super关键字,调用父类的constructor方法。

    2.2 static (静态方法)

    通过static关键字为一个class创建静态方法

     1 class student{
     2     //静态属性
     3     static p = 2;
     4     //构造方法
     5     constructor(name,age,sex){
     6         this.name=name
     7         this.age=age
     8         this.sex=sex
     9     }
    10     //实例方法     dream(){console.log('月薪过万。')}
    12 }
    13 // 静态属性调用
    14 console.log(student.p)

    2.3 类的继承 extends

     1 class A {
     2      constructor(){
     3             this.name = 'Marry'
     4             this.age= 18
     5         }
     6     read(){console.log(this.name+this.age)}
     7 }
     8 class B extends A {
     9     constructor(props) {
    10         super(props)     
    11     }
    12     s(){
    13         console.log(this.name+this.age)
    14     }
    15 }
    16 var b = new B();
    17 b.s()

    当实例 b 调用 s 方法时,b 本身没有 name和age,会根据继承找到A

    2.4“this”指向问题

    class中的this指向实例时的对象。

    2.5 super( )关键字

    关键字super用于调用父类相应的方法,这是相较于原型继承的一个好处

    三.总体的写法

     1 // 创建一个类存放特有的属性和方法,用来实例对象。
     2 class Student{
     3     // 静态属性只属于Student的属性
     4     static s = "180";
     5     // 静态方法只属于Student的方法
     6     static m(){
     7         console.log("静态方法")
     8     }
     9     // 构造方法
    10     constructor(props){
    11         //实例属性
    12         this.name=props.name;
    13         this.age=props.age;
    14         this.sex=props.sex;
    15     }
    16     // 实例方法
    17     students(){
    18         console.log(this.name+this.age+this.sex)
    19 
    20     }
    21 }
    22 // 静态属性调用
    23 console.log(Student.s)
    24 // 实例化对象
    25 var S1 = new Student('tom',21,'男');
    26 // 调用方法
    27 S1.students()

    以上纯属个人理解,如有疑问欢迎留言

  • 相关阅读:
    剑指offer之第一个只出现一次的字符
    剑指offer之求1+2+...n
    剑指offer求两个整数之和(要求在函数体内不得使用+、-、*、/四则运算符号)
    剑指offer之从上往下打印二叉树
    剑指offer之栈的压入、弹出序列(利用辅助栈)
    58笔试-忘记题目
    联通软研院2020年球季校招笔试第三题 20190916
    简单的计算小技巧
    前端访问不到本地图片,IDEA设置Tomcat虚拟路径
    求最大子列和问题
  • 原文地址:https://www.cnblogs.com/z-j-c/p/12063559.html
Copyright © 2011-2022 走看看