文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

javascript的oop怎么写

2023-07-06 13:02

关注

这篇“javascript的oop怎么写”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“javascript的oop怎么写”文章吧。

  1. 原型(prototype)和构造函数(constructor)

在JavaScript中,一个对象的属性和方法可以通过原型来共享,而构造函数则用于创建一个新对象并初始化其属性。以下是一个使用构造函数和原型的简单例子:

function Person(name, age) {  this.name = name;  this.age = age;}Person.prototype.sayHi = function() {  console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old.");}var person1 = new Person("John", 30);var person2 = new Person("Mary", 25);person1.sayHi(); // Hi, my name is John and I'm 30 years old.person2.sayHi(); // Hi, my name is Mary and I'm 25 years old.

在上面的例子中,我们定义了一个Person构造函数,初始化了nameage属性。然后,我们使用Person.prototype给每个Person对象添加了一个sayHi方法,这个方法可以被所有Person对象共享。最后,我们创建了两个Person对象,并调用了它们的sayHi方法。

  1. 类(class)

在ES6中,JavaScript引入了类的概念,并使用关键字class来实现。类提供了一种更简洁、更易于理解的语法,用于定义对象。

以下是一个使用类的例子:

class Person {  constructor(name, age) {    this.name = name;    this.age = age;  }    sayHi() {    console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old.");  }}let person1 = new Person("John", 30);let person2 = new Person("Mary", 25);person1.sayHi(); // Hi, my name is John and I'm 30 years old.person2.sayHi(); // Hi, my name is Mary and I'm 25 years old.

在上面的例子中,我们使用class关键字定义了一个Person类,并在constructor方法中初始化了nameage属性。然后,我们定义了一个sayHi方法,用于输出一个招呼。最后,我们创建了两个Person对象,并调用了它们的sayHi方法。

  1. 继承(inheritance)

在OOP中,继承是指从一个已有的对象中派生出一个新的对象,新对象继承了原来的对象的属性和方法。在JavaScript中,继承可以通过使用prototypeclass来实现。

以下是使用prototype实现继承的例子:

function Person(name, age) {  this.name = name;  this.age = age;}Person.prototype.sayHi = function () {  console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old.");}function Student(name, age, major) {  Person.call(this, name, age);  this.major = major;}Student.prototype = Object.create(Person.prototype);Student.prototype.constructor = Student;Student.prototype.sayMajor = function() {  console.log("My major is " + this.major + ".");}let person1 = new Person("John", 30);let student1 = new Student("Mary", 25, "Computer Science");person1.sayHi(); // Hi, my name is John and I'm 30 years old.student1.sayHi(); // Hi, my name is Mary and I'm 25 years old.student1.sayMajor(); // My major is Computer Science.

在上面的例子中,我们定义了一个Person构造函数,在原型中添加了sayHi方法。另外,我们定义了一个Student构造函数,通过使用call方法调用了Person构造函数来初始化nameage属性,并添加了一个major属性。然后,我们使用Object.create方法创建了一个Person.prototype的副本,并将其指定给Student.prototype,以便Student对象可以继承Person对象的属性和方法。最后,我们定义了一个sayMajor方法,用于输出学生的专业。最终,我们创建了一个Person对象和一个Student对象,并调用了他们的方法。

以下是使用class实现继承的例子:

class Person {  constructor(name, age) {    this.name = name;    this.age = age;  }    sayHi() {    console.log("Hi, my name is " + this.name + " and I'm " + this.age + " years old.")  }}class Student extends Person {  constructor(name, age, major) {    super(name, age);    this.major = major;  }    sayMajor() {    console.log("My major is " + this.major + ".");  }}let person1 = new Person("John", 30);let student1 = new Student("Mary", 25, "Computer Science");person1.sayHi(); // Hi, my name is John and I'm 30 years old.student1.sayHi(); // Hi, my name is Mary and I'm 25 years old.student1.sayMajor(); // My major is Computer Science.

在上面的例子中,我们定义了一个Person类,在constructor方法中初始化了nameage属性,并在sayHi方法中输出了一个招呼。然后,我们使用extends关键字创建了一个Student类,并使用super关键字调用了Person类的constructor方法来初始化nameage属性,并添加了一个major属性。最后,我们定义了一个sayMajor方法,用于输出学生的专业。最终,我们创建了一个Person对象和一个Student对象,并调用了他们的方法。

以上就是关于“javascript的oop怎么写”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网行业资讯频道。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯