[回顾]从原型链视角解读Vue底层实现Vue VueCompoent VM VC关系

news/2025/2/27 1:18:50

从原型链视角解读VueComponent与Vue关系
在这里插入图片描述

原型链

根据,原型链涉及三个关键属性:__proto__是所有对象的私有属性,指向原型链的第一个元素;prototype是函数的属性实例对象不拥有它;constructor指向构造函数。提到原型链是JS中实现继承的机制,通过属性链式查找属性,直到顶端null。进一步解释了原型链的终点是null,而Object.prototype的__proto__指向null。

然后,需要讨论原型链的应用,比如继承和共享方法属性。和都提到原型链可以实现属性和方法的共享,节省内存。的面试题分析了几种继承方法的优缺点,需要注意引用类型属性的问题。

还要注意原型链的验证方法,如instanceof和Object.getPrototypeOf的使用,这在和中都有提到。此外,原型链的终点是null,这点在中专门讨论过。

最后,总结原型链的重要性,以及理解它对掌握JS继承机制的关键作用。需要结合多个证据中的示例,比如中的People构造函数实例,中的Dog和Animal例子,来具体说明原型链的工作流程。

以下是一篇关于前端原型链的解读文章,结合了多篇权威资料的分析与实例:


前端原型链深度解析:从底层机制到应用实践

一、原型链的核心概念

原型链是JavaScript实现继承的核心机制,其本质是通过对象的``(浏览器中可通过__proto__访问)形成的链式结构。关键概念包括:

  1. __proto__:所有对象的内置属性,指向其构造函数的原型对象(即prototype)。
  2. prototype:函数特有的属性,指向该函数的原型对象。例如Person.prototype包含所有实例共享的方法。
  3. constructor:原型对象的属性,指向构造函数本身。例如Person.prototype.constructor === Person
二、原型链的组成与运行机制
  1. 链式结构形成
    当创建实例时(如const person = new Person()):
    • person.__proto__指向Person.prototype
    • Person.prototype.__proto__指向Object.prototype
    • Object.prototype.__proto__最终指向null,此为原型链终点
   person → Person.prototype → Object.prototype → null
  1. 属性查找规则
    访问对象属性时(如person.toString()),JS引擎沿原型链逐级查找:
    • 先在实例自身查找
    • 未找到则向上一级原型对象查找
    • 直到找到属性或到达null(返回undefined
三、原型链的典型应用场景
  1. 实现继承
javascript">   function Animal(name) {
    this.name = name; }
   Animal.prototype.eat = function() {
    console.log("Eating..."); };

   function Dog(name) {
    
     Animal.call(this, name); // 继承实例属性
   }
   Dog.prototype = Object.create(Animal.prototype); // 继承原型方法
   Dog.prototype.bark = function() {
    console.log("Woof!"); };

   const dog = new Dog("Buddy");
   dog.eat(); // 继承自Animal 
  1. 方法共享优化
    所有实例共享原型方法,相比在构造函数内定义方法可节省内存:
javascript">   function Person(name) {
    this.name = name; }
   // 推荐将方法定义在原型上
   Person.prototype.sayName = function() {
    return this.name; };
四、关键验证方法与陷阱
  1. 原型链检测工具
    • instanceof:检查构造函数的prototype是否出现在对象原型链中
    • Object.getPrototypeOf():ES5标准方法获取对象原型(优于直接访问__proto__
javascript">   console.log(dog instanceof Animal); // true 
  1. 常见陷阱
    • 引用类型共享问题
      若父类原型包含引用类型属性(如数组),所有子类实例会共享该属性:
javascript">     function Parent() {
   }
     Parent.prototype.nums = [1, 2];
     const child1 = new Parent();
     child1.nums.push(3); // child2.nums也会变为[1,2,3]
  • 构造函数丢失问题
    直接覆盖子类原型时需修正constructor指向:
javascript">     Dog.prototype = Object.create(Animal.prototype);
     Dog.prototype.constructor = Dog; // 修正constructor 
五、原型链与ES6 Class的关系

ES6的class本质是语法糖,底层仍基于原型链:

javascript">class Animal {
   
  constructor(name) {
    this.name = name; }</

http://www.niftyadmin.cn/n/5869346.html

相关文章

计算机网络————(三)

前文二 前文一 Websocket协议 是一种存在TCP协议之上的协议 当客户端需要了解服务器是否更新就需要不断给客户端发送请求询问是否更新&#xff0c;这行会造成服务端压力很大 而Websocket相当于服务器一旦更新了就会给客户端发送消息表明自己更新了&#xff0c;类似客户端订阅…

模型蒸馏:让人工智能更智能、更小、更高效的艺术

你有没有想过,我们如何才能让一个需要巨大计算能力的庞大人工智能模型变得更精简、更快速、更强大?答案在于模型蒸馏,这是一种允许知识从大型、计算成本高昂的人工智能系统转移到较小、更高效的系统的技术,而不会牺牲智能。 什么是模型蒸馏 模型蒸馏是一种技术,其…

神经网络 - 神经元

人工神经元(Artificial Neuron)&#xff0c;简称神经元(Neuron)&#xff0c;是构成神经网络的基本单元&#xff0c;其主要是模拟生物神经元的结构和特性&#xff0c;接收一组输入信号并产生输出。 生物学家在 20 世纪初就发现了生物神经元的结构。一个生物神经元通常具有多个树…

基于GO语言的车牌识别api技术-港澳车牌文字识别

随着科技的飞速发展&#xff0c;智能化管理逐渐渗透到我们生活的方方面面。车牌识别技术作为智能交通的重要组成部分&#xff0c;不仅极大提升了交通管理的效率&#xff0c;还为市民出行带来了更多便利。而港澳地区的车牌识别技术&#xff0c;凭借其高效、精准、快速的特点&…

自动化反编译微信小程序工具-e0e1-wx

一、项目地址 https://github.com/eeeeeeeeee-code/e0e1-wx 二、简介 1.还在一个个反编译小程序吗&#xff1f;2.还在自己一个个注入hook吗&#xff1f;3.还在一个个查看找接口、查找泄露吗&#xff1f;现在有自动化辅助渗透脚本了&#xff0c;自动化辅助反编译、自动化注入…

vue2项目打包后js文件过大, 首次加载缓慢

vue2项目打包后js文件过大, 首次加载缓慢 安装插件 npm i compression-webpack-plugin6.1.1 -D配置vue.config.js const CompressionWebpackPlugin require(compression-webpack-plugin)module.exports {configureWebpack: {plugins:[new CompressionWebpackPlugin({filen…

QT C++ QtConcurrent::run 异步任务 简单例子

QtConcurrent命名空间提供了高级API&#xff0c;使得无需使用低级线程原语即可编写多线程程序。 ‌QtConcurrent::run‌是Qt框架中用于简化并发编程的一个功能&#xff0c;主要用于在后台线程中异步执行函数或成员函数。其主要用途包括&#xff1a; ‌异步执行函数‌&#xf…

java23种设计模式-享元模式

享元模式&#xff08;Flyweight Pattern&#xff09;学习笔记 1. 模式定义 结构型设计模式&#xff0c;通过共享技术实现大量细粒度对象的复用&#xff0c;有效减少内存占用并提高性能。核心思想&#xff1a;分离内部状态&#xff08;可共享&#xff09;与外部状态&#xff0…