项目中肯定会常用的一些基础组件,比如弹窗,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)
The end~