JS 底层探究-- 普通函数和构造函数

一、核心理论

1. 普通函数 vs 构造函数

  • 普通函数 :小驼峰命名 getUser(),直接调用,返回数据 / 执行逻辑

例如:

javascript 复制代码
function getUser (name) {
  retrun {name};
}
  • 构造函数大驼峰命名 User(),必须用 new 调用,用来创建对象

例如:

javascript 复制代码
// 构造函数(大驼峰命名)
function Person(name, age) {
  // 自身属性
  this.name = name;
  this.age = age;
}

2. new 关键字四大步骤

  1. 创建一个空对象 {}
  2. 这个空对象的 __proto__ 指向构造函数的 prototype
  3. 构造函数内部的 this 指向这个空对象
  4. 如果构造函数没有返回对象,则默认返回这个新对象
javascript 复制代码
// 1. 先定义一个构造函数
function Person(name, age) {
  // 步骤3执行时,this 会变成我们创建的空对象
  this.name = name;
  this.age = age;
}

// ------------------------------
// 核心:手写模拟 new 的4大步骤
// ------------------------------
function myNew(constructor, ...args) {
  // 步骤1:创建一个空对象 {}
  const obj = {};

  // 步骤2:空对象的 __proto__ 指向构造函数的 prototype
  obj.__proto__ = constructor.prototype;

  // 步骤3:执行构造函数,让 this 指向这个空对象
  // call 的作用:把构造函数里的 this 改成 obj
  const result = constructor.call(obj, ...args);

  // 步骤4:如果构造函数没有返回对象,就返回我们创建的 obj
  if (result && typeof result === "object") {
    return result;
  } else {
    return obj;
  }
}

// ------------------------------
// 测试使用
// ------------------------------
const p1 = myNew(Person, "小明", 18);
console.log(p1);       // Person { name: '小明', age: 18 }
console.log(p1.name);  // 小明

3. 实例与构造函数关系

  • new 构造函数() → 得到实例对象
javascript 复制代码
const a = new Person("XIAO MIN", 20);
  • 多个实例之间互相独立
javascript 复制代码
const b = new Person("XIAO HUA", 29)

console.log(a); // Person { name: 'XIAO MIN', age: 20 }
console.log(b); // Person { name: 'XIAO HUA', age: 29 }

4. 自身属性 vs 原型属性

  • 自身属性this.xxx 挂载的属性,每个实例独立拥有
javascript 复制代码
console.log(a.name); // XIAO MIN
Person.prototype.pName = "Person"
console.log(a.pName); // Person
  • 原型属性 :在 构造函数.prototype 上,所有实例共享
javascript 复制代码
console.log(b.name) // XIAO HUA
console.log(b.pName) // Person
相关推荐
小白不白1112 小时前
C# WinForm 与 VP 二次开发
开发语言·c#
程序猿乐锅2 小时前
【JAVASE | 第十七篇】Java 网络通信
java·开发语言
飞舞哲2 小时前
三维点云最小二乘拟合MATLAB程序
开发语言·算法·matlab
有点。2 小时前
C++(贪心算法二)
开发语言·c++·贪心算法
meilindehuzi_a2 小时前
透视 V8 底部:从物理内存到函数式哲学,重新解构 JavaScript 数组
开发语言·javascript·ecmascript
jllllyuz2 小时前
HVDC 高压直流输电系统 MATLAB/Simulink 仿真全集
开发语言·matlab
我命由我123452 小时前
Windows 操作系统 - Windows 查看防火墙是否开启、Windows 查看防火墙放行端口
java·运维·开发语言·windows·java-ee·操作系统·运维开发
粉末的沉淀2 小时前
vue:Vite项目中高效管理纯色SVG图标的方案
前端·javascript·vue.js
FlyWIHTSKY2 小时前
JavaScript 和 TypeScript 分别是什么,可以相互写吗
javascript·ubuntu·typescript