关于JavaScript面向对象中构造函数和原型对象的学习与理解

简介: 面向对象就是把需要解决的问题分解成一个个对象,建立对象不是为了实现一个步骤,而是为了描述每个对象在解决问题中的行为,面向对象的核心是对象。

📚关于面向对象

面向对象就是把需要解决的问题分解成一个个对象,建立对象不是为了实现一个步骤,而是为了描述每个对象在解决问题中的行为,面向对象的核心是对象。

关于面向对象思想,我们可以将同一类事物的操作代码封装成对象,将用到的变量和函数作为对象的属性和方法,然后通过对象去调用,这样可以使代码结构清晰、层次分明。在团队开发中,使用面向对象思想编程可以帮助团队更好地协助分工,提高开发效率。

通过下面这张图片我们可以大致了解面向对象所包含的内容

image.gif

❗关于面向对象编程的优势如下。

  • 模块化更深,封装性强。
  • 更容易实现复杂的业务逻辑。
  • 更易维护、易复用、易扩展。

❗关于JavaScript开发中的面向对象设计思想,以及类的基本使用就不一一介绍了

📚构造函数和原型对象

1️⃣构造函数

构造函数主要用来创建对象,并为对象的成员赋初始值。我们可以把对象中的一些公共的属性和方法抽取出来,封装到构造函数中。

functionPerson (name, age) {
this.name=namethis.age=agethis.say=function () {
console.log('i can say')
  }
}
constp1=newPerson('a', 21)
constp2=newPerson('b', 20)
console.log(p1.name)
console.log(p2.age)
p2.say()
image.gif

上述代码用面向对象思想封装了一个Person构造函数,在构造函数中,有name和age两个属性,以及say()方法。

❗构造函数和类的区别

类中的成员方法是定义在类中的,使用类创建对象后,这些对象的方法都是引用了同一个方法,这样可以节省内存空间。

classPerson {
say () {
console.log('hi')
   }
}
constp1=newPerson()
constp2=newPerson()
console.log(p1.say===p2.say)
image.gif

image.gif

使用构造函数创建的对象并不是引用同一个方法,示例代码如下。

functionPerson () {
this.say=function () {
console.log('i can say')
  }
}
constp1=newPerson()
constp2=newPerson()
console.log(p1.say===p2.say)
image.gif

image.gif

2️⃣原型对象

为了解决上述问题,就需要利用原型对象来实现。

在JavaScript中,每个构造函数都有一个原型对象存在,这个原型对象通过构造函数的prototype属性来访问,示例代码如下。

functionPlay () {
}
console.log(Play.prototype)
console.log(typeofPlay.prototype)
image.gif

image.gif

在上述代码中,Play函数的prototype属性指向的对象就是Play的原型对象。

利用原型对象,可以实现为所有的实例对象共享实例方法,我们可以将实例方法定义在原型对象中,然后所有的实例方法就都可以访问原型对象的方法了。因此,原型对象其实就是所有实例对象的原型。下面我们通过代码演示原型对象的使用。

functionPerson (name) {
this.name=name}
Person.prototype.sayHello=function () {
console.log('你好,我叫'+this.name)
}
constp1=newPerson('张三')
constp2=newPerson('李四')
console.log(p1.sayHello===p2.sayHello)// 输出结果:truep1.sayHello()// 输出结果:你好,我叫张三p2.sayHello()// 输出结果:你好,我叫李四
image.gif

image.gif

从上述代码可以看出,实例对象p1和p2原本没有sayHello()方法,但是在为原型对象添加了sayHello()方法以后,p1和p2就都拥有了sayHello()方法,并且是同一个方法。在原型对象的方法中,this表示的是调用此方法的实例对象。

目录
打赏
0
0
0
0
4
分享
相关文章
【Java进阶】详解JavaScript的BOM(浏览器对象模型)
总的来说,BOM提供了一种方式来与浏览器进行交互。通过BOM,你可以操作窗口、获取URL、操作历史、访问HTML文档、获取浏览器信息和屏幕信息等。虽然BOM并没有正式的标准,但大多数现代浏览器都实现了相似的功能,因此,你可以放心地在你的JavaScript代码中使用BOM。
45 23
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
63 1
JavaScript中对象的数据拷贝
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
72 1
JavaScript中的原型 保姆级文章一文搞懂
如何学习JavaScript?
如何学习JavaScript?
115 5
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
58 2
JS中的构造函数的含义和用法
构造函数是JavaScript中用于创建新对象的特殊函数,通常首字母大写。通过`new`关键字调用构造函数,可以初始化具有相同属性和方法的对象实例,从而实现代码复用。例如,定义一个`Person`构造函数,可以通过传入不同的参数创建多个`Person`对象,每个对象都有自己的属性值。此外,构造函数还可以包含方法,使每个实例都能执行特定的操作。构造函数的静态属性仅能通过构造函数本身访问。ES6引入了`class`语法糖,简化了类的定义和实例化过程。
88 1
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
83 1
JavaScript常用的内置构造函数
JavaScript提供的内置构造函数在数据处理、对象创建、异常处理和异步操作等方面发挥了重要作用。掌握这些构造函数及其用法,对于开发高效、可靠的JavaScript应用至关重要。通过合理使用这些内置构造函数,开发者可以更好地管理和操作各种类型的数据,提升开发效率和代码质量。
49 1