VUE组件全局自动注册 及 VUEx仓库module自动导入

组件全局注册 页面无需引入直接做标签使用

  1. 读取需要全局自动注册的文件 例如:在src的components中wholeSituation文件夹

test和test2为全局注册组件

  1. wholeSituation根目录新建index.js文件

export default {
  install(Vue) {
//自动读取文件夹下的文件require.context()
//require.context('需要读取的文件路径','是否读取子文件夹 boolean值','需要读取的文件-正则匹配')
    const req = require.context('./', true, /.vue$/)
//函数内keys方法,keys方法调用后返回所有读取文件的路径
    req.keys().forEach((item) => {
//req(读取的文件路径)可以相当于导入对应的文件     返回值.default的内容就是导入的文件
      const com = req(item).default
//此处的name名注意!!!!使用是的标签名称就是文件中的name名
      Vue.component(com.name, com)
    })
  }
}
  1. 在main.js中做导入

import test from '@/components/wholeSituation/index.js'
Vue.use(test)

完事!!!!!!

Store自动注册modules

  1. 同上查找文件

const modulesFiles = require.context('./modules',true,/\.js$/)
const modules = modulesFiles.keys().reduce((modules,modulePath)=>{
const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/,'$1')
const value = modulesFiles(modulePath)
modules[moduleName] = value.default
return modules
},{})
//最后导入
const store = new Vuex.Store({
modules,
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值