基于 Vite + Vue3 的组件自动注册功能

实现一个基于 Vite + Vue3 的组件自动注册功能,能让你无需手动 import 和注册组件,直接在模板中使用。

实现思路

  1. 使用 Vite 的 import.meta.glob 方法批量导入指定目录下的所有组件
  2. 创建一个组件注册插件,自动全局注册所有导入的组件
  3. 提供组件使用示例和目录结构规范

完整实现代码

1. 组件自动注册插件 (src\components\common\index.js)

javascript 复制代码
/**
 * 全局公共组件自动注册
 * 自动注册src/components/common目录下的所有组件
 */

// 导入所有公共组件
import JmForm './JmForm .vue'
import JmTable from './JmTable.vue'
 
/**
 * 自动导入并注册组件
 * @param {Object} app - Vue应用实例
 * @param {Array} exclude - 排除的组件名称列表
 */
export function registerCommonComponents(app, exclude = []) {
  // 组件列表
  const components = {
    JmForm ,
    JmTable
 
  }

  // 注册所有组件
  Object.entries(components).forEach(([name, component]) => {
    // 检查是否在排除列表中
    if (exclude.includes(name)) {
      return
    }
    
    // 全局注册组件
    app.component(name, component)
  })
}

export default {
  registerCommonComponents
}
  1. 入口文件引入插件 (src/main.js)
javascript 复制代码
// 导入全局公共组件自动注册
import { registerCommonComponents } from './components/common';
  1. 写一个组件页面

  2. 直接使用组件 (src/App.vue) 无需引入

html 复制代码
<template>
  <!-- 无需import,直接使用 -->
  <jm-form v-model="form" :items="items" />
  <jm-table :data="list" :columns="columns" /> 
</template>
相关推荐
ZC跨境爬虫2 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人2 小时前
HTML 字符引用完全指南
开发语言·前端·html
matlab_xiaowang2 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
幼儿园技术家2 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
前端摸鱼匠4 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker4 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding5 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马6 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren6 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川6 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端