封装公共组件中在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))
相关推荐
心连欣38 分钟前
解锁对象遍历:当字符串遇上for...in循环
前端·javascript
Sestid41 分钟前
前端Cursor使用指南(后续会更新Claude)
前端·claude·cursor
戴维南1 小时前
LangChain 在 Agent 开发中的定位:10 个模块(含代码对比,耳机售后案例)
前端
ouzz1 小时前
使用纯canvas绘制一个掘金首页
前端·canvas
用户6957584491281 小时前
Vue 3 响应式系统:解构赋值与依赖收集的正确姿势
前端
乐乐同学yorsal1 小时前
一个 TypeScript 写的图片视频处理工具箱,吊打一切付费软件!
前端·命令行
账号已注销free1 小时前
Vue3项目中给组件命名的方式
vue.js
前端那点事1 小时前
VueUse 全面指南|Vue3组合式工具集实战
vue.js
lzhdim1 小时前
SQL 入门 10:SQL 内置函数:数值、字符串与时间处理
前端·数据库·sql
jstopo网站1 小时前
水厂水泵工作流程图canvas动画
前端·javascript