vue中注册组件的两种方式详解(全局注册&& 局部注册)

 更新时间:2023年06月24日 10:04:49   作者:蓝胖子的多啦A梦  
vue 是一个完全支持组件化开发的框架, 组件之间可以进行相互的引用,这篇文章主要介绍了vue中注册组件的两种方式详解(全局注册&& 局部注册),需要的朋友可以参考下

vue 是一个完全支持组件化开发的框架, 组件之间可以进行相互的引用。vue 中组件的引用原则:先注册后使用。

1. 组件的注册

组件之间可以进行相互的引用,例如:

注册组件的的方式:分为“全局注册”和“局部注册”两种,其中:

全局注册的组件,可以在全局任何一个组件内使用
局部注册的组件,只能在当前注册的范围内使用

1)全局注册组件

在main .js 中引用

import Vue from 'vue'
//导入 dialogBox 和Test 两个组件
import dialogBox from './components/InfoMessage/index.vue';
import Test from './components/MyTest.vue'
Vue.component('dialogBox', dialogBox)
Vue.component('my-test', Test)

2)使用全局注册组件

使用app.component() 方法注册的全局组件,直接以标签的形式进行使用即可,例如:

 //在 main.js中,注册了dialogBox 和my-test两个全局组件
Vue.component('dialogBox', dialogBox)
Vue.component('my-test', Test)
 <!--在其他组件中,直接以标签的形式,使用刚才注册的全局组件即可
 <template>
 <h1>这是App根组件</h1>
 <hr/>
 <dialogBox></dialogBox>
<my-test></my-test>
 </template>

3)局部注册组件

<template>
 <h1>这是App根组件</h1>
<my-swiper></my-swiper>
<my-search></my-search>
 </template>
 <script>
 import Search from './components/MySearch.vue'
 export default {
components:{// 通过 components节点,为当前的组件注册私有子组件
'my-search': Search,
 },
}
 </script>

2.全局注册和局部注册的区别

全局注册的组件,可以在全局任何一个组件内使用
局部注册的组件,只能在当前在这里插入代码片注册的范围内使用

应用场景

如果某些组件在开发期间的使用频率很高,推荐进行全局注册;
如果某些组件只在特定的情况下会被用到,推荐进行局部注册

3.组件注册时名称的大小写

在进行组件的注册时,定义组件注册名称的方式有两种:

①使用kebab-case命名法(俗称短横线命名法,例如my-test 和my-search)

②使用PascalCase命名法(俗称帕斯卡命名法大驼峰命名法,例如MyTest和MySearch)

短横线命名法的特点:

必须严格按照短横线名称进行使用

帕斯卡命名法的特点:

既可以严格按照帕斯卡名称进行使用,又可以转化为短横线名称进行使用

注意:在实际开发中,推荐使用帕斯卡命名法为组件注册名称,因为它的适用性更强

4.通过name 属性注册组件

在注册组件期间,除了可以直接提供组件的注册名称之外,还可以把组件的name 属性作为注册后组件的名称,

示例代码如下:

5.组件之间的样式冲突问题

默认情况下,写在.vue 组件中的样式会全局生效,因此很容易造成多个组件之间的样式冲突问题。导致组件之间样式冲突的根本原因是:

单页面应用程序中,所有组件的DOM 结构,都是基于唯一的index.html 页面进行呈现的

每个组件中的样式,都会影响整个index.html 页面中的DOM 元素

到此这篇关于vue中注册组件的两种方式(全局注册&amp;&amp; 局部注册)的文章就介绍到这了,更多相关vue注册组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 使用Element+vue实现开始与结束时间限制

    使用Element+vue实现开始与结束时间限制

    这篇文章主要为大家详细介绍了使用Element+vue实现开始与结束时间限制,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • Vue设置别名联想路径即@/生效的方法

    Vue设置别名联想路径即@/生效的方法

    这篇文章主要给大家介绍了Vue设置别名联想路径即@/生效的方法,文中有详细的代码示例和图文讲解,具有一定的参考价值,需要的朋友可以参考下
    2023-11-11
  • vue-cli实现多页面多路由的示例代码

    vue-cli实现多页面多路由的示例代码

    本篇文章主要介绍了vue-cli实现多页面多路由的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-01-01
  • Element-UI表格嵌入popover遇到的问题及解决方案

    Element-UI表格嵌入popover遇到的问题及解决方案

    在表格中我们通常需要在每一行的一些单元格中显示popover,这篇文章主要给大家介绍了关于Element-UI表格嵌入popover遇到的问题及解决方案,需要的朋友可以参考下
    2023-11-11
  • 关于Vue中keep-alive的作用及使用方法

    关于Vue中keep-alive的作用及使用方法

    keep-alive是Vue的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,该组件将不会销毁,这篇文章主要介绍了关于Vue中keep-alive的作用是什么?怎么使用,需要的朋友可以参考下
    2023-04-04
  • Vue开发中整合axios的文件整理

    Vue开发中整合axios的文件整理

    这篇文章主要给大家整理了在Vue开发中整合axios要用到的文件,在vue开发中,不可避免要整合axios,文中通过示例代码介绍的非常详细,需要的朋友们下面来一起看看吧。
    2017-04-04
  • vue 路由页面之间实现用手指进行滑动的方法

    vue 路由页面之间实现用手指进行滑动的方法

    下面小编就为大家分享一篇vue 路由页面之间实现用手指进行滑动的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随跟随小编过来看看吧
    2018-02-02
  • Vue+Django项目部署详解

    Vue+Django项目部署详解

    这篇文章主要介绍了Vue+Django项目部署详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-05-05
  • 移动端滑动切换组件封装 vue-swiper-router实例详解

    移动端滑动切换组件封装 vue-swiper-router实例详解

    这篇文章主要介绍了移动端滑动切换组件封装 vue-swiper-router实例详解,需要的朋友可以参考下
    2018-11-11
  • elementUI给el-tabs/el-tab-pane添加图标效果实例

    elementUI给el-tabs/el-tab-pane添加图标效果实例

    这篇文章主要给大家介绍了关于elementUI给el-tabs/el-tab-pane添加图标效果实例的相关资料,文中通过实例代码介绍的非常详细,对大家学习或者使用elementUI具有一定的参考学习价值,需要的朋友可以参考下
    2023-07-07

最新评论