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
相关推荐
用户2986985301419 分钟前
在 React 中使用 JavaScript 将 Excel 转换为 PDF
javascript·react.js·webassembly
用户938515635073 小时前
从 Prompt 到 Harness:AI 工程化的三年跃迁与实战解码
javascript·人工智能
木木剑光3 小时前
我开源了一个 React 组件库,沉淀了多个高频组件和实用 Hooks
前端·javascript·react.js
竹林8184 小时前
Solana DApp 开发踩坑实录:从零用 @solana/web3.js 实现链上数据查询与交易签名
前端·javascript
梯度不陡4 小时前
Signal #17:Agent 开始进入组织系统
前端·javascript
胡萝卜术4 小时前
从暴力到Z字形消元:力扣240「搜索二维矩阵II」的降维打击之路
前端·javascript·面试
云浪5 小时前
前端二进制数组完全指南:ArrayBuffer、TypedArray、DataView 一次讲透
前端·javascript
铁皮饭盒6 小时前
26年bunjs, elysia+pg一把梭, redis都省了
前端·javascript·后端
kyriewen19 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
free3520 小时前
从 0 实现一个 Tiny JavaScript VM:项目架构拆解
javascript