js学习笔记之class类、super和extends关键词

yizhihongxing

JS学习笔记之Class类、super和extends关键词攻略

介绍

在ES6之前,JavaScript是一门纯粹的面向对象语言,而没有类的概念,而是采用基于原型的继承方式。在ES6之后,JavaScript引入了Class类、super和extends关键词,使得JavaScript的面向对象变得更加完善。Class语法让JavaScript的对象声明,操作和继承更加直观。

  • Class:定义一个包含特定属性和方法的对象模板,通过new实例化或者extends继承使用
  • super:super关键字用于调用父类的构造函数,或者调用父类中的方法和属性
  • extends:用来继承某个类,可以在一个子类中使用 extends关键字后接父类名,然后在构造函数中调用super方法来调用父类的构造函数

Class类

创建一个类

在JavaScript中创建一个类很简单,只需要使用class关键字就可以定义一个类,然后使用new关键字进行实例化

class Person{
  constructor(name, age){
    this.name = name;
    this.age = age;
  }
  greeting(){
    console.log(`Hello, my name is ${this.name}, I'm ${this.age} years old.`);
  }
}
let person1 = new Person('John', 30);
person1.greeting(); //输出:Hello, my name is John, I'm 30 years old.

类的继承

继承是面向对象编程中的一个重要概念,ES6提供了Class关键字来实现类的继承,也就是子类可以继承父类的属性和方法

class Student extends Person{
  constructor(name, age, major){
    super(name, age);
    this.major = major;
  }
  introduce(){
    console.log(`My major is ${this.major}.`);
  }
}
let student1 = new Student('Lucy', 20, 'Math');
student1.greeting(); //输出:Hello, my name is Lucy, I'm 20 years old.
student1.introduce(); //输出:My major is Math.

super

super关键字是一种引用父类方法的方式,它可以用来调用父类方法或者构造函数。在子类的构造函数中,如果要使用父类的构造函数,就需要使用super方法。 当我们需要继承父类的方法时,也可以通过super关键字调用父类的方法,并且可以带上相关的参数

class Animal{
  constructor(name){
    this.name = name;
  }
  run(){
    console.log(`${this.name} is running.`);
  }
}
class Dog extends Animal{
  constructor(name, breed){
    super(name);
    this.breed = breed;
  }
  run(){
    super.run();
    console.log(`A ${this.breed} dog is running.`);
  }
}
let dog1 = new Dog('Mike', 'Husky');
dog1.run(); //输出:Mike is running. A Husky dog is running.

在子类的run()方法中调用父类的run()方法,打印出“Mike is running.”。之后,又打印出了“`A Husky dog is running.”

extends

extends关键字用于类之间的继承,在一个子类中使用extends关键字继承父类的属性和方法。利用继承,可以使用父类进行代码共享,并且可以更容易地扩展类的功能,同时也可以更好地维护代码

class Animal{
  constructor(name){
    this.name = name;
  }
  run(){
    console.log(`${this.name} is running.`);
  }
}
class Dog extends Animal{
  constructor(name, breed){
    super(name);
    this.breed = breed;
  }
  shout(){
    console.log(`A ${this.breed} dog is barking.`);
  }
}
let dog1 = new Dog('Mike', 'Husky');
dog1.run(); //输出:Mike is running.
dog1.shout(); //输出:A Husky dog is barking.

在上面的代码中,我们定义了一个Animal类来创建一个动物对象和一个Dog类来创建一个狗对象。通过extend关键字,Dog类可以继承自Animal类,并且扩展了一个新的方法shout()

结论

在JavaScript中Class类、super和extends关键词被广泛使用,使得JavaScript的面向对象编程变得更加直观。使用Class类可以方便的创建实例化对象,使用继承可以共享代码,并且更容易地维护代码。super关键字则能够方便地调用父类的方法或构造函数,从而避免了重复性的代码。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:js学习笔记之class类、super和extends关键词 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • jscript与vbscript 操作XML元素属性的代码

    为了操作 XML 元素属性,我们需要使用 XML DOM 对象。在 JavaScript 中,我们可以使用 jscript 或者 vbscript 来访问和操作 XML DOM。 XML DOM 对象是一个树结构,由节点组成。每个节点都有一个节点类型,例如元素节点、属性节点、文本节点等。我们可以通过节点的属性和方法来访问和操作节点的内容。 下面是使用 jsc…

    JavaScript 2023年6月10日
    00
  • JavaScript中常见加密解密方法总结

    JavaScript中常见加密解密方法总结 在前端开发中,加密和解密是常用的技术手段之一,它们可以保证前端传递的数据安全性。本文将介绍一些常见的JavaScript加密和解密方法。 Base64编码解码 Base64编码是将二进制数据转化为纯文本的一种编码方式。在前端传递数据时,常常需要对敏感信息进行编码,以保证数据的安全。 以下是一个简单的示例,演示如何使…

    JavaScript 2023年5月19日
    00
  • JavaScript+html5 canvas制作的百花齐放效果完整实例

    下面我将为您详细讲解“JavaScript+html5 canvas制作的百花齐放效果完整实例”的完整攻略。 需求分析 首先我们需要明确需求,对于“JavaScript+html5 canvas制作的百花齐放效果完整实例”,我们需要实现什么样的效果呢? 具体而言,我们需要实现以下特点: 在canvas上绘制出多个不同颜色、不同形状的花朵 花朵应该随机飘落、旋…

    JavaScript 2023年6月10日
    00
  • javascript常用方法总结

    作为网站作者,我可以为您提供“Javascript常用方法总结”的完整攻略。 1. 简介 Javascript是一种广泛应用于web开发的编程语言,它具有很多强大的方法,可以对页面上的元素进行操作、获取信息、修改样式等等。在本篇攻略中,我将为大家梳理一些常用的javascript方法及其使用方法,希望能对前端开发的同学有所帮助。 2. 常用方法 2.1. g…

    JavaScript 2023年5月17日
    00
  • Javascript 面向对象 对象(Object)

    下面是 Javascript 面向对象 对象(Object)的完整攻略: 理解概念 JavaScript 的面向对象和其他语言很相似,都是基于类和实例的概念。但是 JavaScript 中没有类,而是通过对象来实现面向对象编程。 对象可以看作是一个属性的集合,每个属性都是由键值对(key-value pair)组成,键名是字符串,键值可以是任意的 JavaS…

    JavaScript 2023年5月27日
    00
  • 利用js来实现缩略语列表、文献来源链接和快捷键列表

    要实现缩略语列表、文献来源链接和快捷键列表的功能,可以使用一些JavaScript库和工具来完成,常见的包括jQuery和Bootstrap等。 缩略语列表 Markdown中可以通过使用缩略语的方式来节约篇幅。可以使用JavaScript来添加一个缩略语列表,让用户能够快速查看和了解所有的缩略语含义。 实现步骤: (1)首先需要在Markdown文档中定义…

    JavaScript 2023年6月10日
    00
  • 10行原生JS实现文字无缝滚动(超简单)

    当根据文章中提供的攻略,我们可以用不到十行的原生JS代码实现文字无缝滚动的效果。下面逐步解读这个攻略的实现过程: 第一步:获取DOM元素 首先,需要获取到需要滚动的文字所在的DOM元素。这可以通过document.querySelector()方法来获取。在示例中,需要滚动的文字是包含在一个<div>元素中的,其class为scroll-wrap…

    JavaScript 2023年6月11日
    00
  • 聊一聊JavaScript作用域和作用域链

    下面是详细讲解“聊一聊JavaScript作用域和作用域链”的完整攻略。 JavaScript中的作用域 JavaScript中的作用域是指变量的适用范围,也就是变量能够被访问的区域。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。 全局作用域 全局作用域是指在所有函数外部定义的变量,它的作用域范围是整个JavaScript程序。在全局作…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部