前端面试题-JavaScriptl原型,原型链?有什么特点?(2024.2.2)

一、先理解下构造函数,实例对象 (看代码的打印结果和解释)

构造函数(Constructor)的 prototype 属性: 当你创建一个函数时,JavaScript 会自动为该函数创建一个 prototype 属性。这个 prototype 属性是一个对象,它包含可以由该构造函数创建的所有实例共享的属性和方法。

对象的 __proto__ 属性: 每个对象都有一个 __proto__ 属性,它指向该对象的原型。当你访问一个对象的属性时,JavaScript 引擎会首先查找对象本身是否有这个属性,如果没有,就会去查找对象的原型(通过 __proto__ 找到原型对象),以此类推,直到找到该属性或到达原型链的末尾。

javascript 复制代码
// 构造函数
function Person(name) {
  this.name = name;
}

// 通过构造函数创建对象
var person1 = new Person('Alice');

// person1 的原型是 Person 构造函数的 prototype 属性
console.log(person1.__proto__ === Person.prototype); // 输出: true

// Person 构造函数的 prototype 的原型是 Object 构造函数的 prototype
console.log(Person.prototype.__proto__ === Object.prototype); // 输出: true

// Object 构造函数的 prototype 的原型是 null,这是原型链的终点
console.log(Object.prototype.__proto__ === null); // 输出: true
  • __proto__ 是访问原型的非标准方法,它通常被称为"隐式原型"。
  • 在现代 JavaScript 中,你应该使用 Object.getPrototypeOf()Object.create() 等方法来访问和设置原型。

二、原型、原型链

  1. 原型(prototype)

    • 每个 JavaScript 对象都有一个原型对象,它是一个指向另一个对象的引用。
    • 原型对象可以包含属性和方法,它们可以被对象实例继承。
    • 在 JavaScript 中,对象实例可以通过 Object.prototype 访问到它的原型对象。
  2. 原型链(prototype chain)

    • 当访问一个对象的属性或方法时,JavaScript 引擎会先查找该对象本身是否具有这个属性或方法。如果没有,它会继续查找对象的原型对象,以此类推,直到找到该属性或方法,或者达到原型链的顶端(即 Object.prototype)。
    • 这种对象之间通过原型链连接起来的结构被称为原型链。
  3. 特点

    • 继承关系:原型链实现了对象之间的继承关系,允许对象实例继承原型对象的属性和方法。
    • 动态性:可以在运行时动态地改变和扩展对象的原型。这意味着你可以在程序执行过程中修改对象的原型,对所有继承自该原型的对象都会产生影响。
    • 原型和实例之间的关系 :对象实例与它的原型之间存在连接,通过 __proto__ 属性(不建议直接使用,可以使用 Object.getPrototypeOfObject.setPrototypeOf)可以访问到实例的原型对象。
javascript 复制代码
// 示例
function Animal(name) {
  this.name = name;
}

// 创建 Animal 的实例
const cat = new Animal('Cat');

// 演示原型链
console.log(cat.hasOwnProperty('name'));  // true,实例本身有 name 属性
console.log(cat.hasOwnProperty('toString'));  // false,toString 是从原型链继承而来的
console.log('toString' in cat);  // true,toString 是在原型链上找到的

console.log(Object.getPrototypeOf(cat) === Animal.prototype);  // true,实例的原型是 Animal.prototype
console.log(Animal.prototype.isPrototypeOf(cat));  // true,Animal.prototype 是 cat 的原型
相关推荐
code_YuJun21 分钟前
corepack 作用
前端
千寻girling22 分钟前
Koa.js 教程 | 一份不可多得的 Node.js 的 Web 框架 Koa.js 教程
前端·后端·面试
全栈前端老曹23 分钟前
【MongoDB】Node.js 集成 —— Mongoose ORM、Schema 设计、Model 操作
前端·javascript·数据库·mongodb·node.js·nosql·全栈
code_YuJun24 分钟前
pnpm-workspace.yaml
前端
天才熊猫君26 分钟前
“破案”笔记:iframe动态加载内容后,打印功能为何失灵?
前端
五月君_43 分钟前
炸裂!Claude Opus 4.6 与 GPT-5.3 同日发布:前端人的“自动驾驶“时刻到了?
前端·gpt
Mr Xu_1 小时前
前端开发中CSS代码的优化与复用:从公共样式提取到CSS变量的最佳实践
前端·css
鹏北海-RemHusband1 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied1 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年1 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式