news 2026/4/12 22:10:39

搞懂构造函数与原型,才算真正入门 JavaScript 面向对象

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
搞懂构造函数与原型,才算真正入门 JavaScript 面向对象

本文将带你从构造函数与原型这两个核心概念入手,拆解它们的设计初衷与协作逻辑,从而理解 JavaScript 独特的编程思想。

为什么需要构造函数?

在 JavaScript 中,当我们需要创建多个具有相同属性和方法的对象时,直接使用对象字面量会产生大量重复代码。
构造函数正是为了解决这个问题而生,它让对象的创建更具规范性和可维护性。

1. 构造函数的作用

  • 批量创建对象:通过一个模板快速生成多个结构相似的实例。
  • 初始化实例:在创建对象时,就为其赋予初始的属性和行为。
  • 标识类型:通过 instanceof 可以判断对象的构造函数,从而明确其 “类型”。

2. 基础示例

// 定义构造函数functionPerson(name,age){this.name=name;this.age=age;this.sayHello=function(){console.log(`你好,我是${this.name},今年${this.age}`);};}// 创建实例constp1=newPerson("张三",22);constp2=newPerson("李四",25);p1.sayHello();// 你好,我是张三,今年22岁p2.sayHello();// 你好,我是李四,今年25岁// 验证类型console.log(p1instanceofPerson);// true

冗余问题

每个实例都会单独创建一个 sayHello 方法。

这不仅浪费内存,也不符合代码复用的思想。

console.log(p1.sayHello===p2.sayHello);// false// 说明每个实例的sayHello都是一个新的函数对象

如果创建 1000 个 Person 实例,就会生成 1000 个完全相同的 sayHello 函数,这在性能和内存上都是极大的浪费。

原型(共享与复用的关键)

为了解决方法冗余的问题,JavaScript 引入了原型(Prototype)机制。
每个函数都有一个 prototype 属性,它指向一个对象,我们称之为原型对象。

原型的特性

  • 共享机制:所有通过该构造函数创建的实例,都会共享原型对象上的属性和方法。
  • 查找链:当访问实例的一个属性或方法时,如果实例本身没有,就会去原型对象上查找。
  • 动态更新:对原型对象的修改会立即反映到所有现有实例上。

优化后的代码

functionPerson(name,age){this.name=name;this.age=age;}// 将方法定义在原型上Person.prototype.sayHello=function(){console.log(`你好,我是${this.name},今年${this.age}`);};// 新增共享属性Person.prototype.species="人类";constp1=newPerson("张三",22);constp2=newPerson("李四",25);console.log(p1.sayHello===p2.sayHello);// trueconsole.log(p1.species);// 人类console.log(p2.species);// 人类

构造函数 + 原型

在 ES6 之前,JavaScript 并没有真正的 class 关键字。

它正是通过构造函数 + 原型的组合,模拟出了面向对象中 “类” 的效果。

ES6 Class 的本质

ES6 引入的 class 语法,其实只是构造函数 + 原型的语法糖。

它让代码更符合传统面向对象的写法,但底层逻辑并未改变。

// ES6 Class 写法classPerson{constructor(name,age){this.name=name;this.age=age;}// 实例方法,会被挂载到原型上sayHello(){console.log(`你好,我是${this.name},今年${this.age}`);}// 静态方法,不会被挂载到原型上staticcreate(name,age){returnnewPerson(name,age);}}// 底层依然是构造函数 + 原型console.log(typeofPerson);// functionconsole.log(Person.prototype.sayHello);// [Function: sayHello]// 使用静态方法创建实例constp3=Person.create("王五",30);p3.sayHello();// 你好,我是王五,今年30岁

原型链与继承

原型的作用不止于方法复用,它还是 JavaScript 实现继承的基础。

通过修改构造函数的原型指向另一个类型的实例,就能让该类型的实例继承另一个类型的属性和方法,这就是原型链继承。

原型链继承示例

// 父类构造函数functionAnimal(name){this.name=name;}Animal.prototype.eat=function(){console.log(`${this.name}正在吃东西`);};// 子类构造函数functionDog(name,breed){Animal.call(this,name);// 继承父类的属性this.breed=breed;}// 继承父类的方法Dog.prototype=Object.create(Animal.prototype);Dog.prototype.constructor=Dog;// 修复constructor指向// 子类的方法Dog.prototype.bark=function(){console.log(`${this.name}正在汪汪叫`);};constmyDog=newDog("旺财","中华田园犬");myDog.eat();// 旺财正在吃东西myDog.bark();// 旺财正在汪汪叫

总结

总的来说,理解构造函数与原型是打通 JavaScript 编程思想的关键一环:构造函数解决了对象批量创建与初始化的痛点,而原型则完美实现了属性与方法的共享复用,二者相辅相成,共同构成了 JavaScript 面向对象编程的核心基础。

掌握这些底层逻辑,不仅能让你写出更高效、更优雅的代码,更能为后续深入学习原型链、继承、ES6 Class 等高级概念筑牢根基。
当你再面对复杂的业务场景时,就能用更贴近语言本质的方式去设计代码,真正做到知其然,更知其所以然。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/10 17:36:52

Z-Image-Turbo如何实现照片级真实感?实测告诉你

Z-Image-Turbo如何实现照片级真实感?实测告诉你 你有没有试过输入“一位穿米色风衣的亚洲女性站在秋日银杏大道上,阳光斜照,发丝微扬,背景虚化”,然后等30秒——结果生成的图里,风衣纹理像塑料布&#xff0…

作者头像 李华
网站建设 2026/4/12 14:58:27

从0开始学AI绘画:Z-Image-Turbo_UI界面新手入门

从0开始学AI绘画:Z-Image-Turbo_UI界面新手入门 1. 这不是另一个复杂部署教程,而是一次真正“开箱即用”的体验 你是不是也经历过这样的时刻:看到一个惊艳的AI绘画模型,兴致勃勃点开文档,结果被密密麻麻的环境配置、…

作者头像 李华
网站建设 2026/4/10 21:05:16

[Linux]学习笔记系列 -- [drivers][clk]clk-bulk

title: clk-bulk categories: linuxdriversclk tags:linuxdriversclk abbrlink: fc0f43c4 date: 2025-10-03 09:01:49 https://github.com/wdfk-prog/linux-study 文章目录drivers/clk/clk-bulk.c 批量时钟控制(Bulk Clock Control) 简化多路时钟管理历史与背景这项技术是为了…

作者头像 李华
网站建设 2026/4/10 14:52:04

Luminous系列的详细讨论 / Detailed Discussion of the Luminous Series

Luminous系列的详细讨论 / Detailed Discussion of the Luminous Series引言 / IntroductionLuminous系列是德国人工智能初创公司Aleph Alpha开发的欧洲领先多模态大型语言模型(LLM)家族,自2022年起成为欧洲争夺AI主权的核心发力点。该系列以…

作者头像 李华
网站建设 2026/4/10 16:34:20

SGLang服务启动命令详解,参数不再难懂

SGLang服务启动命令详解,参数不再难懂 你是否在启动SGLang服务时,面对python3 -m sglang.launch_server后面一长串参数感到困惑?——--model-path到底填什么路径?--host 0.0.0.0和127.0.0.1有什么区别?--log-level wa…

作者头像 李华
网站建设 2026/4/10 8:09:23

智能家居报警场景下proteus蜂鸣器仿真指南:操作指南

以下是对您提供的博文内容进行 深度润色与结构重构后的专业级技术文章 。全文严格遵循您的所有要求: ✅ 彻底去除AI痕迹,语言自然、老练、有“人味”; ✅ 摒弃模板化标题与刻板结构,以逻辑流驱动叙述节奏; ✅ 所有…

作者头像 李华