封装公共组件中在main.js中通过插件统一注册

插件:插件 (Plugins) 是一种能为 Vue 添加全局功能的工具代码(也可以注册组件)

https://cn.vuejs.org/guide/reusability/plugins.html

全局注册组件:https://cn.vuejs.org/guide/components/registration.html

javascript 复制代码
import { App } from 'vue'
import table from './src/index.vue' //引入组件

// 让这个组件可以通过use的形式使用
export default {
  install(app: App) {
    app.component('m-table', table) //插件为注册组件
  }
}
javascript 复制代码
import { App } from 'vue'
// 每一个引入的都是一个插件
import chooseArea from './chooseArea' 
import chooseIcon from './chooseIcon'
import trend from './trend'
import notification from './notification'
import list from './list'
import menu from './menu'
import chooseTime from './chooseTime'
import chooseDate from './chooseDate'
import progress from './progress'
import chooseCity from './chooseCity'
import form from './form'
import modalForm from './modalForm'
import table from './table'
import calendar from './calendar'

const components = [
  chooseArea,
  chooseIcon,
  trend,
  notification,
  list,
  menu,
  chooseTime,
  chooseDate,
  chooseCity,
  progress,
  form,
  modalForm,
  table,
  calendar
]

export default {
  install(app: App) {
    // 循环中使用插件
    components.map(item => {
      app.use(item)
    })
  }
}

最后可以在main.js

javascript 复制代码
import mUI from './components'

app.use(use(mUI))
相关推荐
超哥--2 小时前
B站视频内容智能分析系统(九):React 前端与管理面板
前端·react.js·前端框架
Cutecat_5 小时前
视频字幕处理工具横向:提取模式 vs 编辑模式,该如何选择
android·前端·ios·语音识别
dsyyyyy11015 小时前
JavaScript变量
开发语言·javascript·ecmascript
qq_422152575 小时前
PDF 加水印工具怎么选?2026 年文档版权保护方案对比
前端·pdf·github
kyriewen5 小时前
手写 Promise.all、race、any:不到 30 行代码,解决并发异步的所有姿势
前端·javascript·面试
brucelee1866 小时前
OpenClaw 浏览器控制(Chrome MCP)完整教程
前端·chrome
ct9786 小时前
React 状态管理方案深度对比
开发语言·前端·react
胡志辉的博客6 小时前
深入浅出理解浏览器事件循环:从一道输出题讲到 Chrome 源码
前端·javascript·chrome·chromium·event loop
代码不加糖7 小时前
js中不会冒泡的事件有哪些?
前端·javascript·vue.js
懂懂tty7 小时前
Vue2与Vue3之间API差异
前端·javascript·vue.js