Vue.use的实现原理

一、Vue.use 是做什么的?

  • use 概念
    如果你希望编写一个 Vue.js 插件来扩展应用的功能,需要提供一个 install 方法。如果插件是一个对象,那么这个对象必须包含 install 方法;如果插件是一个函数,那么这个函数将被作为 install 方法。当 install 方法被调用时,Vue 实例会作为参数传入,这样插件就不再需要直接依赖 Vue。(扩展应用的功能)

示例:

// 定义一个插件对象
const MyPlugin = {// 定义 install 方法install(Vue) {// 添加全局方法或属性Vue.myGlobalMethod = function() {// 全局方法逻辑};// 添加全局指令Vue.directive('my-directive', {bind(el, binding, vnode, oldVnode) {// 全局指令逻辑}});// 添加实例方法Vue.prototype.$myMethod = function(methodOptions) {// 实例方法逻辑};}
};// 使用插件
Vue.use(MyPlugin);
  • 插件的功能
    添加全局指令、全局过滤器(Vue3 不再支持过滤器)、全局组件。
    通过全局混入来添加一些组件选项。
    添加实例方法,通过把它们添加到 Vue.prototype / app.config.globalProperties上实现。
  • 实现原理
Vue.use = function (plugin) {// 插件缓存const installedPlugins = this._installedPlugins || (this._installedPlugins = []);// 检查是否已经安装过该插件,如果是则直接返回if (installedPlugins.indexOf(plugin) > -1) {return this;}// 整合除了第一个参数(plugin)之外的其他参数为数组const args = toArray(arguments, 1);// 将 Vue 实例作为第一个参数放入数组中args.unshift(this);// 判断插件类型并安装if (typeof plugin.install === "function") {// 如果插件是一个对象,则调用其 install 方法plugin.install.apply(plugin, args);} else if (typeof plugin === "function") {// 如果插件是一个函数,则直接调用该函数plugin.apply(null, args);}// 将插件缓存起来installedPlugins.push(plugin);// 返回 Vue 实例return this;
};

Vue3 中使用app.use进行插件的注册,原理同 Vue2~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/19486.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Flask-app.py运行】已解决Cannot run program “D:\APP\python\python.exe”

文章目录 一、问题描述二、解决方法 一、问题描述 Cannot run program “D:\APP\python\python.exe” (in directory “F:\Codes\竞赛\大计赛\group\code\web\web”): CreateProcess error2, 系统找不到指定的文件。 这段报错源于运行 flask 项目的 app.py 时报错找不到程序&…

C++ | Leetcode C++题解之第119题杨辉三角II

题目&#xff1a; 题解&#xff1a; class Solution { public:vector<int> getRow(int rowIndex) {vector<int> row(rowIndex 1);row[0] 1;for (int i 1; i < rowIndex; i) {row[i] 1LL * row[i - 1] * (rowIndex - i 1) / i;}return row;} };

SNCScan:针对SAP安全网络通信(SNC)的安全分析与评估工具

关于SNCScan SNCScan是一款针对SAP安全网络通信&#xff08;SNC&#xff09;的安全分析与评估工具&#xff0c;该工具旨在帮助广大研究人员分析SAP安全网络通信&#xff08;SNC&#xff09;&#xff0c;并分析和检测SNC配置与SAP组件中的潜在问题。 SNC系统参数 SNC基础 SAP协…

flutter sdk升级之空安全启用

公司项目flutter sdk需要从2.5升级到3.7。由于项目不支持空安全&#xff0c;所以升级sdk之前要做的第一件事就是启用空安全。以下为空安全适配过程记录。 启用空安全 将dart sdk设置成sdk: ">2.12.0 <3.0.0"&#xff0c;即可启用。代码如下&#xff1a; envi…

面向Java程序员的Go工程开发入门流程

对于一个像我这样没有go背景的java程序员来说&#xff0c;使用go开发一个可用的程序的速度是肉眼可见的缓慢。 其难点不在于go语言本身&#xff0c;而是搭建整个工程链路的过程&#xff0c;即所谓的“配环境”。 本文主要讲述如何配出一个适合go开发的环境&#xff0c;以免有同…

未来工厂新篇章:大型工厂3D可视化技术引领工业新潮流

在科技日新月异的今天&#xff0c;大型工厂不再是我们印象中机器轰鸣、尘土飞扬的钢铁丛林&#xff0c;而是变成了智慧与效率并存的现代化生产中心。这一切的改变&#xff0c;都离不开一项革命性的技术——3D可视化。 一、何为大型工厂3D可视化&#xff1f; 大型工厂3D可视化&…

MATLAB函数模块光显示zeros/poles怎么办?

出现下面这种图了怎么办&#xff1f;是做错了吗&#xff1f; 这种图就是它显示不完整了&#xff0c;把它拉大点就可以完全显示了。

K8s Ingress 详解

文章目录 K8s Ingress 详解Ingress 资源清单Ingress 基于URL 实现路由Ingress 基于名称虚拟主机Ingress 实现HTTPS创建TLS 证书创建Secrets配置ingress Ingress RewriteIngress 灰度发布Ingress 配置认证 K8s Ingress 详解 Ingress 资源清单 apiVersion: networking.k8s.io/v…

ubuntu22 部署nacos集群

#nacos集群 至少需要启动三个nacos &#xff08;这里我只有俩台虚拟机&#xff0c;故在一台上启动了俩个nacos服务&#xff09; https://github.com/alibaba/nacos/releases #下载编译后压缩包 nacos-server-$version.tar.gz cd /usr/local tar -zxvf nacos-server-2.3.2.tar.…

mysql 查询指定id的所有下级数据

为了查询指定ID所有下级数据&#xff0c;你可以使用递归的公用表表达式&#xff08;Common Table Expressions, CTEs&#xff09;。以下是一个例子&#xff0c;假设你有一个名为categories的表&#xff0c;它有id和parent_id字段&#xff0c;parent_id表示父级分类的ID。 WITH…

2024年人文发展与社会科学国际会议(ICHDSS 2024)

2024年人文发展与社会科学国际会议 2024 International Conference on Humanities Development and Social Sciences 【1】会议简介 2024年人文发展与社会科学国际会议是一个汇集全球人文科学和社会科学领域专家学者的盛会。本次会议旨在深入探讨人文发展的多元性、复杂性以及社…

如何查看本地sql server数据库的ip地址

程序连线SQL数据库&#xff0c;需要SQL Server实例的名称或网络地址。 1.查询语句 DECLARE ipAddress VARCHAR(100) SELECT ipAddress local_net_address FROM sys.dm_exec_connections WHERE SESSION_ID SPID SELECT ipAddress As [IP Address]SELECT CONNECTIONPROPERTY(…

SOLIDWORKS参数化开发 慧德敏学

传统的设计模式下大规模定制型产品结构设计周期长&#xff0c;问题多&#xff0c;以及大量重复性工作让工程师疲于应对&#xff0c;这些严重阻碍了公司订单承接能力和技术创新能力&#xff0c;难以响应市场需求。 什么是参数化设计&#xff1f; 1、它是一种设计的方式&#x…

科研项目书写作学习(持续更新中...)

写好一个科研项目书也是科研中很重要的一部分&#xff0c;所以借这篇博客做一个积累。还是以模块化的方式吧&#xff0c;后面慢慢那再整合逻辑。可能写的也不是很好&#xff0c;慢慢提升吧~ 背景 科研项目书的背景怎么写&#xff1f;首先要突出问题的价值(也就是做此研究的动…

华为设备RIP基础路由实验

华为设备RIP基础路由实验 实验拓扑&#xff1a; RIP&#xff1a;距离矢量的动态路由&#xff0c;路由通信有方向&#xff0c;度量值metric取值范围&#xff08;1-16&#xff09;16表示目标主机不可达。 路由的版本分为&#xff1a;RIPV1&#xff08;广播通信目标地址是255.255…

pytorch学习day2

1 数据加载Dataset PyTorch的数据读取机制主要依赖于Dataset和DataLoader这两个核心组件。它们用于加载和处理数据&#xff0c;以便在训练模型时进行高效的数据流动和处理。 Dataset Dataset是一个抽象类&#xff0c;用户可以继承这个类并重载以下两个方法来创建自定义的数据集…

吴恩达深度学习个人笔记

1. 上一个视频提到的房地产领域,我们不就使用了一个普遍标准神经网络架构吗 而对于图像识别处理问题,我们则要使用卷积神经网络(Convolution Neural Network),即CNN。 对于序列数据,例如音频,有一个时间组件,随着时间的推移,音频被播放出来, 所以音频是最自然的表…

Mac下载docker

先安装homebrew Mac下载Homebrew-CSDN博客 然后输入以下命令安装docker brew install --cask --appdir/Applications docker 期间需要输入密码。输入完等待即可

Kubernetes (K8s) 普及指南

在当今的云计算和微服务时代&#xff0c;Kubernetes&#xff08;简称K8s&#xff09;已经成为容器编排的标准工具。它帮助开发者和运维人员管理和部署应用程序&#xff0c;实现高可用性、可伸缩性和自我修复。本文将详细介绍Kubernetes的基本概念、核心组件、工作原理及其优势。…

刷机 iPhone 进入恢复模式

文章目录 第 1 步&#xff1a;确保你有一台电脑&#xff08;Mac 或 PC&#xff09;第 2 步&#xff1a;将 iPhone 关机第 3 步&#xff1a;将 iPhone 置于恢复模式第 4 步&#xff1a;使用 Mac 或 PC 恢复 iPhone需要更多协助&#xff1f; 本文转载自&#xff1a;如果你忘记了 …