登录
首页 >  文章 >  前端

JS构造函数用法与实战解析

时间:2025-12-04 15:38:52 127浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

编程并不是一个机械性的工作,而是需要有思考,有创新的工作,语法是固定的,但解决问题的思路则是依靠人的思维,这就需要我们坚持学习和更新自己的知识。今天golang学习网就整理分享《JS构造函数模式详解与应用》,文章讲解的知识点主要包括,如果你对文章方面的知识点感兴趣,就不要错过golang学习网,在这可以对大家的知识积累有所帮助,助力开发能力的提升。

构造函数模式通过函数定义对象结构,使用new创建实例,如Person构造函数生成person1和person2;new操作会创建新对象、绑定this、关联原型并执行构造逻辑;方法定义在prototype上可避免内存浪费;ES6的class是其语法糖,本质仍基于原型机制。

js构造函数模式是什么

JavaScript 中的构造函数模式是一种创建对象的方式,它利用函数作为对象的模板,通过 new 关键字来生成实例。这种模式适合需要创建多个具有相同结构和行为的对象场景。

什么是构造函数

构造函数本质上是一个普通函数,但有以下特点:

  • 函数名通常首字母大写(约定俗成,便于识别)
  • 内部使用 this 指向即将创建的实例
  • 通过 new 操作符调用,生成新对象
例如:
function Person(name, age) {
  this.name = name;
  this.age = age;
  this.greet = function() {
    console.log("你好,我是" + this.name);
  };
}

const person1 = new Person("小明", 25);
person1.greet(); // 输出:你好,我是小明

new 操作符做了什么

当你使用 new 调用构造函数时,JavaScript 引擎会自动执行以下步骤:

  • 创建一个全新的空对象
  • 将这个新对象的原型(__proto__)指向构造函数的 prototype
  • 将构造函数内部的 this 绑定到这个新对象
  • 执行构造函数中的代码(为对象添加属性和方法)
  • 如果构造函数没有返回其他对象,则返回这个新对象

构造函数的问题与优化

直接在构造函数中定义方法(如上面的 greet)会导致每个实例都创建一份独立的方法副本,浪费内存。

解决办法是将方法挂载在 prototype 上:

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

Person.prototype.greet = function() {
  console.log("你好,我是" + this.name);
};

const person1 = new Person("小明", 25);
const person2 = new Person("小红", 23);
console.log(person1.greet === person2.greet); // true,共用同一个方法

现代替代方案

ES6 引入了 class 语法,它是构造函数的语法糖,更清晰易读:

class Person {
  constructor(name, age) {
    this.name = name;
    this.age = age;
  }
  greet() {
    console.log("你好,我是" + this.name);
  }
}

底层依然是基于原型和构造函数机制。

基本上就这些。构造函数模式是理解 JavaScript 面向对象编程的基础,掌握它有助于深入理解对象创建、原型链和继承机制。

今天关于《JS构造函数用法与实战解析》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>