Javascript 面向对象 继承

JavaScript 是一门面向对象的编程语言,因此在 JavaScript 中实现继承的方式和其他面向对象编程语言如 Java 和 Python 有些区别。下面是一个完整的 JavaScript 面向对象继承攻略,示例说明了两种常用的继承方式。

1. 构造函数继承

构造函数继承是通过在子类构造函数中调用父类构造函数来继承父类属性和方法,这种继承方式存在一个明显的缺点,就是导致父类中的方法无法共享使用。

下面是一个示例代码:

function Person(name, age) {
  this.name = name;
  this.age = age;
}

Person.prototype.sayHello = function() {
  console.log("Hello, I'm " + this.name);
}

// Student 是 Person 的子类
function Student(name, age, grade) {
  Person.call(this, name, age);
  this.grade = grade;
}

这里定义了一个 Person 构造函数,它有两个属性 nameage,还有一个 sayHello 方法。然后定义了一个子类 Student,在构造函数中使用 call 方法调用了 Person 父类的构造函数并传入相应参数,实现了继承。

2. 原型链继承

原型链继承是通过将子类的原型对象设置为父类的实例来实现继承,这种方式可以实现方法共享,但是存在一个问题,就是父类的属性是存在于父类实例中而非父类原型中的,因此无法实现属性的继承。

下面是一个示例代码:

function Person(name, age) {
  this.name = name;
  this.age = age;
}

Person.prototype.sayHello = function() {
  console.log("Hello, I'm " + this.name);
}

// Student 是 Person 的子类
function Student(grade) {
  this.grade = grade;
}

Student.prototype = new Person();

const student = new Student(3);

console.log(student.name); // undefined
console.log(student.age); // undefined
console.log(student.grade); // 3
student.sayHello(); // Hello, I'm undefined

这里定义了一个 Person 构造函数和一个 Student 子类构造函数。定义 Student 的原型对象为 Person 类的实例,实现了继承。但是由于父类 Person 的属性是存在于父类实例中而非父类原型中的,因此无法实现属性的继承。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Javascript 面向对象 继承 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • JS实现的视频弹幕效果示例

    下面是详细讲解“JS实现的视频弹幕效果示例”的完整攻略: 简介 视频弹幕效果是目前比较流行的一种视频播放方式,也可以为网页增加一些互动性。通过JS实现的视频弹幕效果,可以让用户在看视频时发表自己的评论或者观点,同时其他用户也可以看到这些弹幕,增加了互动性。 准备工作 安装编译环境 首先需要安装编译环境,包括node.js,npm,webpack等。如果您还不…

    JavaScript 2023年6月11日
    00
  • js时间转换毫秒的实例代码

    JS时间转换毫秒是一个常用的功能,在前端开发中经常需要对时间进行计算,因此,掌握JS时间转换毫秒的方法是必要的。 1. Date对象的getTime()方法 在JS中,Date对象提供了一个叫做getTime()的方法,可以将日期对象转换成自1970年1月1日 00:00:00 UTC(协调世界时)以来的毫秒数。示例代码如下: var date = new …

    JavaScript 2023年5月27日
    00
  • js下用eval生成JSON对象

    使用eval函数可以将字符串转换为JavaScript代码执行,因此可以使用eval生成JSON对象。以下是生成JSON对象的完整攻略: 1. 准备JSON字符串 首先,你需要准备一个字符串表示的JSON数据。这个JSON字符串必须遵循JSON语法规范,且必须被引号包裹。下面是一个示例JSON字符串: var jsonStr = ‘{"name&q…

    JavaScript 2023年5月27日
    00
  • JavaScript This指向问题详解

    JavaScript This指向问题详解 JavaScript中的this指向是非常重要的一个问题,但也是让很多人感到困惑和烦恼的问题。正确的理解this指向,能够帮助我们更好地编写可读性强、易于维护的JavaScript代码。下面就是关于JavaScript中this指向问题的详解攻略: this的含义 在任何函数中我们都可以使用this关键字。如果我们…

    JavaScript 2023年6月11日
    00
  • JavaScript中数组去重的5种方法

    “JavaScript中数组去重的5种方法”是一个常见的问题,本文将详细讲解五种不同的去重方法。 方法一:使用ES6的Set ES6中新增的Set是一种数据结构,可以用于存储任何类型的唯一值。我们可以使用Set去重一个数组,然后再将其转换为数组类型。 let arr = [1, 2, 2, 3, 3, 4, 5]; let uniqueArr = Array…

    JavaScript 2023年5月27日
    00
  • javascript 循环调用示例介绍

    下面是关于“javascript 循环调用示例介绍”的完整攻略。 什么是循环调用? JavaScript中的循环调用指的是函数自身在执行过程中调用自己的现象,称为递归(recursion),是一种常见的算法设计思想。JavaScript中的递归一般需要终止条件来结束递归,否则会导致栈溢出。循环调用常常用于解决问题的各种算法设计,如搜索、排列、图形算法等。 示…

    JavaScript 2023年6月10日
    00
  • js中arguments对象的深入理解

    深入理解JavaScript中的Arguments对象 在JavaScript中,每个函数在被调用的时候都会自动获取一个名为“arguments”的对象。这个对象中包含了该函数被传入的所有参数,并且可以在函数内部进行访问和操作。 Arguments对象简介 Arguments对象是什么? Arguments对象是一个类数组对象,它包含了当前函数被调用时所传入…

    JavaScript 2023年5月27日
    00
  • Array.reduce使用原理示例详解

    Array.reduce使用原理示例详解 什么是reduce reduce 是 JavaScript 数组 Array 原型中的一个方法,它接收两个参数,第一个参数是函数,第二个参数是初始值。 array.reduce(function callback(accumulator, currentValue, currentIndex, array) { //…

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