当前位置: 首页 > ops >正文

Vue基础知识-重要的内置关系:vc实例.__proto__.__proto__ === Vue.prototype

前言

在 JavaScript 中,原型链是实现继承的核心机制,也是理解框架设计(如 Vue)的重要基础。而 Vue 组件(VueComponent)的原型设计,更是直接依赖于 JS 原型链的特性 —— 通过原型链关联,让组件实例(vc)能访问 Vue 原型上的属性和方法。

一、完整源码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><script src="../js/vue.js"></script>
</head>
<body><div id="root"><student></student></div>
</body><script>/*        function Person(){this.name = "张三"}此时Person有自己的原型,其原型的原型(Person.prototype.prototype)是Object的原型(Object.prototype)访问原型方式(两者等价):1 Person实例.__proto__2 Person.prototypePerson.prototype.age = 18 //通过类给原型添加属性let person = new Person()  person.__proto__.sex = '男'//通过对象给原型添加属性console.log(new Person())  //Person对象有自己的属性name和原型属性age、sex对象访问属性时:1 找自身实例是否有该属性;2 找实例的原型是否有该属性(如Person实例.__proto__);3 就继续顺着原型链往上找(如Person实例.__proto__.__proto__,此时为Object的原型)4 Object的原型的原型为null(返回 undefined)。
*/const student = Vue.extend({template:`<div><h1>学生名称:{{name}}</h1><h1>学生年龄:{{age}}</h1></div>`,data() {return {name:'张三',age:'18'}}})const vm = new Vue({el:'#root',data() {return {n:1}},components:{ student}})/* 重要的内置关系:new student().__proto__.__proto__ === Vue.prototype。即VueComponent原型的原型===Vue的原型因此,vc可以访问Vue原型上的属性、方法 */console.log(new student().__proto__.__proto__ === Vue.prototype) // true</script>
</html>

二、核心知识点解析

1. JavaScript 原型链:从 Person 构造函数说起

原型链的核心逻辑是:每个实例对象都有一个__proto__(原型),其__proto__又指向更高层的原型,直到指向Object原型对象.__proto__ = null(原型链终点)

1.1 代码中原型链的关键操作
  • 构造函数与实例的关系new Person()创建的实例,其__proto__ === Person.prototype(这是原型链的起点)。
    let p = new Person();
    console.log(p.__proto__ === Person.prototype); // true
    
  • 两种操作原型的方式
    1. 通过构造函数操作:Person.prototype.age = 18(直接给Person的原型添加age属性);
    2. 通过实例操作:person.__proto__.sex = '男'(实例的__proto__就是Person.prototype,本质和第一种方式一致)。
  • 原型链查找规则:当访问实例的属性时,会优先查找自身属性 → 若没有则找__proto__(构造函数原型)→ 再找__proto__.__proto__(更高层原型)→ 直到null(找不到返回undefined)。
    例如访问new Person().age:实例自身没有age → 找Person.prototype.age(存在,返回 18)。

2. Vue 组件原型关系:为什么 VC 能访问 Vue 原型的方法?

Vue 中的组件(VueComponent,简称VC)是通过Vue.extend创建的构造函数,其原型设计直接依赖 JS 原型链,核心结论是:VC实例.__proto__.__proto__ === Vue.prototype

2.1 代码中验证
console.log(new student().__proto__.__proto__ === Vue.prototype); // true
2.2 这个设计的意义是什么?

Vue 的原型(Vue.prototype)上挂载了很多全局方法(如$emit$on$nextTick等)。通过将VC的原型链指向Vue.prototypeVC实例就能直接访问这些方法,无需重复定义,实现了方法复用。

例如,我们可以在Vue.prototype上添加一个全局方法,然后在组件中直接调用:

// 给Vue原型添加全局方法
Vue.prototype.sayHi = function() {alert('Hi,我是Vue原型上的方法!');
};// 在student组件中调用
const student = Vue.extend({template: `<div><!-- 其他内容 --><button @click="sayHi">调用全局方法</button></div>`,// ...其他配置
});

点击按钮时,VC实例会通过原型链找到Vue.prototype.sayHi,成功执行方法。

http://www.xdnf.cn/news/19775.html

相关文章:

  • 股指期货可以通过移仓长线持有吗?
  • AppInventor2 如何自定义包名?
  • 华为云云原生架构赋能:大腾智能加速业务创新步伐
  • 【深度学习新浪潮】视觉大模型在预训练方面有哪些关键进展?
  • 鸿蒙UI开发实战:解决布局错乱与响应异常
  • 企业实用——MySQL的备份详解
  • 基于机器学习的Backtrader波动性预测与管理
  • Kubernetes ConfigMap 更新完整指南:原理、方法与最佳实践
  • PyTorch实战——ResNet与DenseNet详解
  • Huggingface终于没忍住,OpenCSG坚持开源开放
  • flume拓扑结构详解:从简单串联到复杂聚合的完整指南
  • Linux 的信号 和 Qt 的信号
  • IO_HW_9_3
  • MySQL数据库恢复步骤(基于全量备份和binlog)
  • 揭秘ArrowJava核心:IndexSorter高效排序设计
  • Cookie、Session、登录
  • 一个工业小白眼中的 IT/OT 融合真相:数字化工厂的第一课
  • SQL Server核心架构深度解析
  • AlexNet:计算机视觉的革命性之作
  • PostgreSQL性能调优-优化你的数据库服务器
  • JVM调优与常见参数(如 -Xms、-Xmx、-XX:+PrintGCDetails) 的必会知识点汇总
  • 【学Python自动化】 9.1 Python 与 Rust 类机制对比学习笔记
  • 【WPS】WPSPPT 快速抠背景
  • 通过SpringCloud Gateway实现API接口镜像请求(陪跑)网关功能
  • 进攻是最好的防守 在人生哲学中的应用
  • 百度智能云「智能集锦」自动生成短剧解说,三步实现专业级素材生产
  • 以太坊网络
  • Spring Boot中MyBatis Plus的LambdaQueryWrapper查询异常排查与解决
  • 外网获取瀚高.NET驱动dll方法和使用案例
  • Axure文件上传高保真交互原型:实现Web端真实上传体验