vue一次注册多个全局组件

项目中肯定会常用的一些基础组件,比如弹窗,toast之类的,要是在每个页面去引入的话那也太麻烦了,还好vue提供了一个全局注册组件的api
Vue.compoment

Vue.component('my-component-name', {
  // ... 选项 ...
})

然后在入口文件main.js里import需要的组件,使用Vue.compoment注册即可

// src/main.js
import model from '@/components/BaseModel'
import toast from '@/components/BaseButton'

Vue.component('BaseModel', BaseModel)
Vue.component('BaseButton', BaseButton)

// 省略其他...

之后再任何页面直接<BaseModel></BaseModel>就可以使用了

但是,如果你的项目很多,封装的全局组件很多,这样一个个引入然后注册就有点麻烦了,为了好管理,最好还是使用动态注册

首先我们把所有的基础组件都放在一个Base的文件夹里面,在里面新建一index.js文件

index.js

// components/base/index
const components = require.context('./', false, /\.vue$/) // require.context获取指定目录下符合条件的文件,这里获取所有base目录下的组件
components.keys().map(item => {
  Vue.components
})
export default Vue => {
  components.keys().map(item => {
    Vue.components(item, components(item).default)
  })
}

src/main.js

import components from '@/src/components/base'

Vue.ues(components)

OK~

猜你喜欢

转载自blog.csdn.net/zzddada/article/details/111213991