vue3 怎么自动全局注册某个目录下的所有 vue 和 tsx 组件

在开发 vue3 项目时,我们会有这样的诉求,怎么自动全局注册某个目录下的所有 vue 和 tsx 组件?

虽然已经有非常强大的 unplugin-vue-components 支持,但是在某些动态场景下,unplugin-vue-components 也选择了不支持。
在这里插入图片描述
那么我们来了解下,在不使用 unplugin-vue-components 的情况下,怎么自动全局注册某个或某些目录下的 vue 或 tsx 组件。

方法一:使用 require.context (适用于 Webpack)

require.context 是 Webpack 提供的一个方法,可以扫描指定目录下符合特定规则的文件,并将其作为模块引入。

  1. 初始化 Vue 应用

    import { createApp } from 'vue';
    const app = createApp({/* 你的应用配置 */});
    
  2. 使用 require.context 查找组件

    const components = require.context('./components', true, /\.vue$|\.tsx$/); // 扫描 './components' 目录及其子目录下的所有 .vue 和 .tsx 文件
    
    • './components':要扫描的目录,相对路径。
    • true:是否递归扫描子目录。false 表示只扫描当前目录,true 表示扫描所有子目录。
    • /\.vue$|\.tsx$/:匹配的文件名规则,这里匹配以 .vue.tsx 结尾的文件。
  3. 全局注册组件

    components.keys().forEach(key => {const componentConfig = components(key); // 导入组件const componentName = key.split('/').pop().replace(/\.(vue|tsx)$/, ''); // 提取组件名 (例如,从 './MyComponent.vue' 中提取 'MyComponent')app.component(componentName, componentConfig.default || componentConfig); // 全局注册组件
    });app.mount('#app'); // 挂载应用
    
    • components.keys():返回所有匹配的文件路径的数组。
    • components(key):根据文件路径导入组件。
    • componentConfig.default || componentConfig:兼容 ES Module 和 CommonJS 两种导出方式。componentConfig.default 用于 ES Module 的 export default,而 componentConfig 用于 CommonJS 的 module.exports

方法二:使用 Vite 的 import.meta.glob (适用于 Vite)

如果你的项目使用 Vite 作为构建工具,可以使用 import.meta.glob 来实现类似的功能。

  1. 使用 import.meta.glob 查找组件

    const components = import.meta.glob('./components/**/*.{vue,tsx}', { eager: true }); // 扫描 './components' 目录及其子目录下的所有 .vue 和 .tsx 文件
    
    • './components/**/*.{vue,tsx}':使用 glob 模式匹配文件。** 表示递归匹配所有子目录。
    • { eager: true }:立即导入所有匹配的模块。如果不使用 eager: true,则会返回一个 promise,需要在注册组件时进行异步处理。
  2. 全局注册组件

    import { createApp } from 'vue';
    const app = createApp({/* 你的应用配置 */});for (const path in components) {const component = components[path];const componentName = path.split('/').pop().replace(/\.(vue|tsx)$/, '');app.component(componentName, component.default || component);
    }app.mount('#app');
    

方法三:创建 Vue 插件

可以将自动注册组件的逻辑封装成一个 Vue 插件,方便在多个项目中复用。

  1. 创建插件文件 (例如 registerComponents.js)

    export default {install: (app) => {const components = import.meta.glob('./components/**/*.{vue,tsx}', { eager: true });for (const path in components) {const component = components[path];const componentName = path.split('/').pop().replace(/\.(vue|tsx)$/, '');app.component(componentName, component.default || component);}}
    };
    
  2. main.js 中安装插件

    import { createApp } from 'vue';
    import App from './App.vue';
    import registerComponents from './registerComponents'; // 导入插件const app = createApp(App);
    app.use(registerComponents); // 安装插件
    app.mount('#app');
    

方法四:使用 index.ts 导出组件

在组件目录下创建一个 index.ts 文件,将所有组件导出,然后在 main.ts 中一次性导入并注册。

  1. 创建 index.ts (位于 components 目录下)

    import MyComponentA from './MyComponentA.vue';
    import MyComponentB from './MyComponentB.vue';
    // 导入更多组件export {MyComponentA,MyComponentB,// 导出更多组件
    };
    
  2. main.ts 中导入并注册

    import { createApp } from 'vue';
    import App from './App.vue';
    import * as components from './components'; // 导入所有组件const app = createApp(App);for (const componentName in components) {app.component(componentName, components[componentName]);
    }app.mount('#app');
    

注意事项:

  • 路径: 确保你的组件目录路径正确。
  • 扩展名: 确认你匹配了所有需要的组件文件扩展名 (.vue, .tsx)。
  • 组件命名: 组件名称将基于文件名生成,请确保你的文件名符合命名规范。
  • 性能: 全局注册组件虽然方便,但可能会增加最终打包体积。如果某些组件只在少数地方使用,建议使用局部注册,以优化性能。
  • TypeScript: 在 TypeScript 项目中,确保正确处理组件的类型定义。

选择哪种方法?

  • require.context 适用于使用 Webpack 的项目。
  • import.meta.glob 适用于使用 Vite 的项目,并且是推荐的方法。
  • Vue 插件: 如果需要在多个项目中使用相同的组件注册逻辑,可以将逻辑封装成一个插件。
  • index.ts 适用于组件数量不多,且希望显式地控制导出组件的情况。

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

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

相关文章

大模型数据集全面整理:444个数据集下载地址

本文针对Datasets for Large Language Models: A Comprehensive Survey 中的 444 个数据集(涵盖8种语言类别和32个领域)进行完整下载地址整理收集。 2024-02-28,由杨刘、曹家欢、刘崇宇、丁凯、金连文等作者编写,深入探讨了大型语…

2025届优秀大数据毕业设计

【2025计算机毕业设计】计算机毕业设计100个高通过率选题推荐,毕业生毕设必看选题指导,计算机毕业设计选题讲解,毕业设计选题详细指导_哔哩哔哩_bilibili 985华南理工大学学长 大厂全栈,大数据开发工程师 专注定制化开发

免费在腾讯云Cloud Studio部署DeepSeek-R1大模型

2024年2月2日,腾讯云宣布DeepSeek-R1大模型正式支持一键部署至腾讯云HAI(高性能应用服务)。开发者仅需3分钟即可完成部署并调用模型,大幅简化了传统部署流程中买卡、装驱动、配网络、配存储、装环境、装框架、下载模型等繁琐步骤。…

【C++高并发服务器WebServer】-17:阻塞/非阻塞和同步/异步、五种IO模型、Web服务器

本文目录 一、阻塞/非阻塞、同步/异步1.1 辨析1.2 异步io接口 二、五种IO模型2.1 阻塞 blocking 模型2.2 非阻塞 NIO 模型2.3 IO多路复用2.4 信号驱动Signal-driven2.5 异步 三、Web Sever 网页服务器3.1 HTTP的请求响应步骤3.2 HTTP请求与响应报文格式3.3 HTTP请求方法3.4 HTT…

【MySQL例题】我在广州学Mysql 系列——有关数据备份与还原的示例

ℹ️大家好,我是练小杰,今天周二,明天就是元宵节了呀!!😆 俗话说“众里寻他千百度。蓦然回首,那人却在,灯火阑珊处。” 本文主要对数据库备份与还原的知识点例题学习~~ 前情回顾&…

自动化xpath定位元素(附几款浏览器xpath插件)

在 Web 自动化测试、数据采集、前端调试中,XPath 仍然是不可或缺的技能。虽然 CSS 选择器越来越强大,但面对复杂 DOM 结构时,XPath 仍然更具灵活性。因此,掌握 XPath,不仅能提高自动化测试的稳定性,还能在爬…

【并发控制、更新、版本控制】.NET开源ORM框架 SqlSugar 系列

系列文章目录 🎀🎀🎀 .NET开源 ORM 框架 SqlSugar 系列 🎀🎀🎀 文章目录 系列文章目录一、并发累计(累加)1.1 单条批量累计1.2 批量更新并且字段11.3 批量更新并且字段list中对应的…

数据存储和操作:数据管理的基石

在数据管理的庞大体系中,数据存储和操作是确保数据可用性和完整性的关键环节。它不仅涉及数据的物理存储,还包括数据的管理、维护和优化。今天,让我们深入《DAMA数据管理知识体系指南(第二版)》的第六章,一…

Redis 数据类型 Hash 哈希

在 Redis 中,哈希类型是指值本⾝⼜是⼀个键值对结构,形如 key "key",value { { field1, value1 }, ..., {fieldN, valueN } },Redis String 和 Hash 类型⼆者的关系可以⽤下图来表⽰。 Hash 数据类型的特点 键值对集合…

支持向量机原理

支持向量机(简称SVM)虽然诞生只有短短的二十多年,但是自一诞生便由于它良好的分类性能席卷了机器学习领域。如果不考虑集成学习的算法,不考虑特定的训练数据集,尤其在分类任务中表现突出。在分类算法中的表现SVM说是排…

zy.21

PHP(续) PHP代码执行漏洞 1.PHP中代码漏洞的概念 代码执行漏洞就是在代码中若存在eval、assert等能将所接收的参数作为代码去执行,并且拼接的内容可被访问者控制,也就是把传入的参数给拼接进去了,造成了额外的代码执行,也就造成了代码执行漏洞。(大概原理&#x…

LSTM 学习笔记 之pytorch调包每个参数的解释

0、 LSTM 原理 整理优秀的文章 LSTM入门例子:根据前9年的数据预测后3年的客流(PyTorch实现) [干货]深入浅出LSTM及其Python代码实现 整理视频 李毅宏手撕LSTM [双语字幕]吴恩达深度学习deeplearning.ai 1 Pytorch 代码 这里直接调用了nn.l…

React - 事件绑定this

在 React 中,this 的绑定是一个常见问题,尤其在类组件中使用事件处理函数时。JavaScript 中的 bind 函数用于设置函数调用时 this 的值。 bind 函数的作用 bind() 方法创建一个新的函数,当被调用时,其 this 关键字被设置为提供的…

Web3 的虚实融合之路:从虚拟交互到元宇宙构建

在这个数字技术日新月异的时代,我们正站在 Web3 的门槛上,见证着互联网的又一次革命。Web3 不仅仅是技术的迭代,它代表了一种全新的交互方式和价值创造模式。本文将探讨 Web3 如何推动虚拟交互的发展,并最终实现元宇宙的构建&…

Kafka简单使用

说明:kafka是一款消息中间件,可实现微服务之间的异步调用。本文介绍kafka的简单使用。windows操作系统下的kafka安装,参考下面这篇文章 Kafka安装 启动 按照上面博客的介绍,使用CMD命令启动,如下: Demo …

【原创精品】基于Springboot3+Vue3的学习计划管理系统

大家好,我是武哥,最近给大家手撸了一个基于SpringBoot3Vue3的学习计划管理系统,可用于毕业设计、课程设计、练手学习,系统全部原创,如有遇到网上抄袭站长的,欢迎联系博主~ 项目演示视频 https://www.bili…

C++引用深度详解

C引用深度详解 前言1. 引用的本质与核心特性1.1 引用概念1.2 核心特性 2. 常引用与权限控制2.1 权限传递规则2.2 常量引用2.3 临时变量保护1. 样例2. 样例3. 测试 三、引用使用场景分析3.1 函数参数传递输出型参数避免多级指针高效传参 3.2 做函数返回值正确使用危险案例 4. 性…

本地部署Deepseek R1

使用Ollama open-webui部署Deepseek R1 一、安装Ollama 官网地址:https://ollama.com/,点击下载按钮选择windows版本。并安装 打开命令提示符输入ollama,出现一下提示命令表示ollama安装完成 二、使用Ollama下载deepseek R1不同模型 打开o…

MATLAB 生成脉冲序列 pulstran函数使用详解

MATLAB 生成脉冲序列 pulstran函数使用详解 目录 前言 一、参数说明 二、示例一 三、示例二 总结 前言 MATLAB中的pulstran函数用于生成脉冲序列,支持连续或离散脉冲。该函数通过将原型脉冲延迟并相加,生成脉冲序列,适用于信号处理和系统…

机器学习(李宏毅)——self-Attention

一、前言 本文章作为学习2023年《李宏毅机器学习课程》的笔记,感谢台湾大学李宏毅教授的课程,respect!!! 二、大纲 何为self-Attention?原理剖析self-Attention VS CNN、RNN、GNN 三、何为self-Attenti…