关于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表示的是调用此方法的实例对象。

相关文章
|
4月前
|
前端开发 JavaScript
个人征信电子版无痕修改, 个人信用报告pdf修改,js+html+css即可实现【仅供学习用途】
本代码展示了一个信用知识学习系统的前端实现,包含评分计算、因素分析和建议生成功能。所有数据均为模拟生成
|
4月前
|
前端开发
个人征信PDF无痕修改软件,个人征信模板可编辑,个人征信报告p图神器【js+html+css仅供学习用途】
这是一款信用知识学习系统,旨在帮助用户了解征信基本概念、信用评分计算原理及信用行为影响。系统通过模拟数据生成信用报告,涵盖还款记录
|
6月前
|
编解码 JavaScript 前端开发
【Java进阶】详解JavaScript的BOM(浏览器对象模型)
总的来说,BOM提供了一种方式来与浏览器进行交互。通过BOM,你可以操作窗口、获取URL、操作历史、访问HTML文档、获取浏览器信息和屏幕信息等。虽然BOM并没有正式的标准,但大多数现代浏览器都实现了相似的功能,因此,你可以放心地在你的JavaScript代码中使用BOM。
188 23
|
5月前
|
JavaScript 数据可视化 前端开发
three.js简单实现一个3D三角函数学习理解
1.Three.js简介 Three.js是一个基于JavaScript编写的开源3D图形库,利用WebGL技术在网页上渲染3D图形。它提供了许多高级功能,如几何体、纹理、光照、阴影等,以便开发者能够快速地创建复杂且逼真的3D场景。同时,Three.js还具有很好的跨平台和跨浏览器兼容性,让用户无需安装任何插件就可以在现代浏览器上观看3D内容。
186 0
|
11月前
|
JSON 前端开发 JavaScript
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
163 1
JavaScript中对象的数据拷贝
|
11月前
|
JavaScript 前端开发
JavaScript中的原型 保姆级文章一文搞懂
本文详细解析了JavaScript中的原型概念,从构造函数、原型对象、`__proto__`属性、`constructor`属性到原型链,层层递进地解释了JavaScript如何通过原型实现继承机制。适合初学者深入理解JS面向对象编程的核心原理。
180 1
JavaScript中的原型 保姆级文章一文搞懂
|
11月前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
209 5
|
11月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
108 2
|
11月前
|
JavaScript 前端开发
JS中的构造函数的含义和用法
构造函数是JavaScript中用于创建新对象的特殊函数,通常首字母大写。通过`new`关键字调用构造函数,可以初始化具有相同属性和方法的对象实例,从而实现代码复用。例如,定义一个`Person`构造函数,可以通过传入不同的参数创建多个`Person`对象,每个对象都有自己的属性值。此外,构造函数还可以包含方法,使每个实例都能执行特定的操作。构造函数的静态属性仅能通过构造函数本身访问。ES6引入了`class`语法糖,简化了类的定义和实例化过程。
196 1

热门文章

最新文章