vue-cli:学会优雅注册全局组件[无脑cv]

Posted 前端呆头鹅

tags:

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

一 普通的全局注册

1.1 定义

首先定义两个组件。

// src>components>rk-a
<template>
  <div class="rk-a">
    第一个全局组件rk-a
  </div>
</template>
// src>components>rk-b
<template>
  <div class="rk-a">
    第二个全局组件rk-b
  </div>
</template>

1.2 注册

在main.js中注册两个组件。

// src>main.js
import RkA from './components/rk-a.vue'
import RkB from './components/rk-b.vue'
...
Vue.component('RkA',RkA)
Vue.component('RkB',RkB)

1.3 使用

在App.vue中使用两个组件。

<template>
  <div id="app">
    <img alt="Vue logo" src="./assets/logo.png">
    <RkA />
    <RkB />
  </div>
</template>

二 优雅的全局注册

上面的注册方式,如果全局组件较多,main.js会比较大,最好能将全局组件统一管理,统一引入。

2.1 注册

在component文件夹下创建index.js。

// src>components>index.js
import RkA from './rk-a.vue'
import RkB from './rk-b.vue'

const components = {
    RkA,
    RkB
}

export default {
    install: (vue) => {
        for(let key in components){
            vue.component(key, components[key]);
        }
    }
}

在main.js中通过index注册两个组件。

// src>main.js
import components from './components'
...
Vue.use(components)
...

2.2 使用

在全局vue中就可以直接使用组件了。

<template>
  <div>
    <RkA />
    <RkB />
  </div>
</template>

2.3 添加全局组件

如果添加了组件rk-c,我们不需要更改main.js,而只需要添加rk-c文件后,在index.js中添加rk-c的注册即可。

// src>components>index.js
import RkA from './rk-a.vue'
import RkB from './rk-b.vue'
import RkC from './rk-c.vue'  // 添加

const components = {
    RkA,
    RkB,
    RkC  //添加
}

export default {
    install: (vue) => {
        for(let key in components){
            vue.component(key, components[key]);
        }
    }
}

以上是关于vue-cli:学会优雅注册全局组件[无脑cv]的主要内容,如果未能解决你的问题,请参考以下文章

ES10-flat 兼容性处理(附代码 无脑cv)

Vue2 全局过滤器(vue-cli)

vue-cli 全局组件的引入和 App.vue局部组件的引入方法区别

如何在 Storybook 中注册全局 Vue 组件?

vue.js注册引用全局消息组件

如何使用 vue-router 注册全局组件