优雅的处理vue注册全局组件

Posted mr-rshare

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了优雅的处理vue注册全局组件相关的知识,希望对你有一定的参考价值。

使用情景:

  有频繁使用的组件 需要进行全局注册

  可以将这些组件都放在components下同一个文件夹下,在此文件夹中建立 一个js文件 代码如下:

  

import Vue from ‘vue‘;

// 修改文件名首字母大写
function changeComponentName (str) {
    return str.charAt(0).toUpperCase() + str.slice(1);
}

// 获取当前文件夹下的的组件
// require.context 三个参数  第一个表示读取文件的路径  第二个表示是否遍历文件的子目录   第三个表示匹配的文件的正则
const requireComponent = require.context(‘.‘, false, /.vue$/);

requireComponent.keys().forEach(fileName => {
    const config = requireComponent(fileName);
    const componetName = changeComponentName(
        // 去掉开头 ./  以及后面.vue
        fileName.replace(/^.//, ‘‘).replace(/.w+$/, ‘‘)
    );
    Vue.component(componetName, config.default || config);
})

最后一步 : 在main.js中引入 当前的js文件,  即可全局使用

以上是关于优雅的处理vue注册全局组件的主要内容,如果未能解决你的问题,请参考以下文章

Vue组件之全局组件与局部组件

Vue组件之全局组件与局部组件

vue优雅使用技巧(一)

vue 注册全局组件

vue中注册组件

vue 注册全局基础组件