zl程序教程

您现在的位置是:首页 >  前端

当前栏目

vue常用组件封装_vue组件全局注册和局部注册

Vue注册封装组件 常用 全局 局部
2023-06-13 09:13:49 时间

大家好,又见面了,我是你们的朋友全栈君。

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

在入口文件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文件

// 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)
  })
}

然后在main.js里代码如下:

// src/main.js
import components from '@/src/components/base'
Vue.ues(components)

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。