Vue全局组件和局部组件的注册

 组件的简介

组件系统是Vue.js其中一个重要的概念,它提供了一种抽象,让我们可以使用独立可复用的小组件来构建大型应用,任意类型的应用界面都可以抽象为一个组件树:

组件的基本使用:

创建一个Vue实例需要创建后才能使用,组件也需要进行注册后才能使用。注册组件分为全局注册和局部注册两种方式。

全局注册

1.注册全局组件

注册组件就是利用Vue.component() 方法,先传入一个自定义组件的名字,然后传入这个组件的配置

//定义一个名为 my-component 的新组件

Vue.component('my-component'),{

  //组件内容写在这里 

template:"  <lable>自己的组件</lable>  "

注:""  不支持换行,使用模板字符串支持换行 ` `

})

如上方式,就说明创建了一个自定义组件,然后可以在Vue实例挂在DOM元素中使用它。

<div id="app">

  <my-cpmponent></my-component>

</div>

<script>

//定义一个名字为my-component的组件

Vue.component('my-component',{

//组件内容写这里

template:"<lable>自己的组件</lable>"

})

//声明一个vue实例

var vm = new Vue({

el:"#app",

)}

</script>

归纳总结

  1. 创建全局组件时,应该使用Vue对象的component方法,这个方法接收两个参数。第一个字符串:表示组件名称, 第二个为一个对象:表示组件内容
  2. 组件要渲染的内容应该写在template选项中,作为其值进行处理
  3. 注册时,推荐组件名称为【小写加分隔符链接的形式】,类似于css属性名的写法
  4. 组件全局注册后,在任何vue实例中都可以使用,但前提是相关vue实例应该在注册后在声明
  5. 组件在使用时,应该以标签形式调用

2.全局组件的进阶使用

(一)组件复用性的基本体现:定义后的组件可以通过标签多次调用

<div id="app">
    <my-component></my-component><!-- 以标签形式使用组件 -->
    <my-component></my-component><!-- 以标签形式使用组件 -->
    <my-component></my-component><!-- 以标签形式使用组件 -->
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<script>
    // 定义一个名为 my-component 的新组件
    Vue.component('my-component', {
        //组件内容写这里
        template: "<div>这是一个全局组件</div>",
    })
    //声明一个vue实例
    var vueApp = new Vue({
        el: '#app',
    })
</script>

(二)组件的template选项

注意:组件中的template只能有一个根元素。下面的情况是不允许的:

template: `<div>这是一个全局组件</div>
            <button>hello</button>`,

如果外层有多个根元素,那么就只会渲染第一个根元素

(三)全局组件可以在其注册后创建的所有vue实例中使用

<div id="app">	<!-- 在第一个vue实例中调用全局组件 -->
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<div id="app1">	<!-- 在第二个vue实例中调用全局组件 -->
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<script>
    // 定义一个名为 my-component 的新组件
    Vue.component('my-component', {
        //组件内容写这里
        template: "<div>这是一个全局组件</div>",
    })
    //声明一个vue实例
    var vueApp = new Vue({
        el: '#app',
    });
    var vueApp = new Vue({
        el: '#app1',
    });
</script>

 

(四)全局组件一定要在所有vue实例创建之前注册定义

<div id="app">
    <p>我是第一个div</p>
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<div id="app1">
    <p>我是第二个div</p>
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<script>
    //声明一个vue实例
    var vueApp = new Vue({
        el: '#app',
    });
     // 定义一个名为 my-component 的新组件
     Vue.component('my-component', {
        //组件内容写这里
        template: "<div>这是一个全局组件</div>",
    })
    var vueApp = new Vue({
        el: '#app1',
    })
</script>

(四)全局组件一定要在所有vue实例创建之前注册定义

<div id="app">
    <p>我是第一个div</p>
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<div id="app1">
    <p>我是第二个div</p>
    <my-component></my-component><!-- 以标签形式使用组件 -->
</div>
<script>
    //声明一个vue实例
    var vueApp = new Vue({
        el: '#app',
    });
     // 定义一个名为 my-component 的新组件
     Vue.component('my-component', {
        //组件内容写这里
        template: "<div>这是一个全局组件</div>",
    })
    var vueApp = new Vue({
        el: '#app1',
    })
</script>

③组件内容中的其他选项

(一)组件中的data必须是函数

可以看出,注册组件时传入的配置和创建Vue实例差不多,但也有不同,其中一个就是data属性必须是一个函数。这是因为如果像Vue实例那样,传入一个对象,由于JS中对象类型的变量实际上保存的是对象的引用,所以当存在多个这样的组件时,会共享数据,导致一个组件中数据的改变会引起其他组件数据的改变。

而使用一个返回对象的函数,每次使用组件都会创建一个新的对象,这样就不会出现共享数据的问题来了

<body>
<div id="app">
    <p>我是第一个div</p>
    <my-component></my-component>
</div>
<script>
    Vue.component('my-component', {
        //组件内容写这里
        template: "<div>{{message}}</div>",
    })
    //声明一个vue实例
    var vueApp = new Vue({
        el: '#app',
        data:function(){
            return{
                message:'这是一个全局组件',
            }
        }
    });
</script>

 

局部注册

注册局部组件

Vue实例中有个选项components可以注册局部组件,注册后就只在该实例作用域下有效

<div id="app">
    <my-component></my-component>
</div>
<script>
    var vueApp = new Vue({
        el: '#app',
        components: {
            'my-component': {
                template: '<div>{{message}}</div>',
                data: function () {
                    return {
                        message: '这是一个局部组件',
                    }
                }
            }
        }
    });
</script>

效果演示
在这里插入图片描述


(一)组件中嵌套

<div id="app">
    <my-component></my-component>	
</div>
<script>
    var vueApp = new Vue({
        el: '#app',
        components: {
            'my-component': {
            	//调用该局部组件下的局部组件<next-component>
                template: '<div>{{message}}<next-component></next-component></div>',
                data: function () {
                    return {
                        message: '这是一个局部组件',
                    }
                },
                components:{
                    'next-component':{
                        template:'<div>这是局部组件下的局部组件</div>'
                    }
                }
            }
        }
    });
</script>

效果图
在这里插入图片描述
可以在组件的components选项中声明多个组件,在components中:每个组件都是一个键值对。键名为组件名,键值为组件内容


(二)在组件中定义子组件时,可以使用外部定义对象作为组件内容

<div id="app">
    <my-component></my-component>
</div>
<script>
    var obj1 = {
        template:`<div>我是第一个子div</div>`
    }
    var obj2 = {
        template:`<div>我是第二个子div</div>`
    }
    Vue.component('my-component',{
        template:`<div>
                    <sub1></sub1>
                    <sub2></sub2>
                  </div>`,
        components: {
            sub1:obj1,
            sub2:obj2
        }
    })
    var vueApp = new Vue({
        el: '#app',
    });
</script>

效果图
在这里插入图片描述


(三)组件调用时可以直接使用单标签形式

<div id="app">
<person-message></person-message>
<person-message/>
</div>

当用单标签多次调用同一组件,只会产生组件一次

 

  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue项目中可以使用全局组件局部组件全局组件是在入口函数main.js中声明的组件。通过在main.js中注册全局组件,可以在任意子组件中直接使用该全局组件,而无需再进行导入、声明和引用的流程。这样可以方便地在整个项目中共享和重用组件局部组件是在组件的父组件中声明的组件。在根组件App.vue中,可以直接在<template>标签中引用局部组件,无需导入和声明。这样的组件只能在父组件及其子组件中使用,不能在其他组件中直接引用。 如果想了解更详细的Vue注册全局组件局部组件的过程解析,可以参考一些相关的教程和示例代码。这些教程和示例代码会详细介绍如何注册和使用全局组件局部组件,对于学习和工作都具有一定的参考价值。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Vue----局部组件全局组件](https://blog.csdn.net/qq_40132294/article/details/124903389)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [VUE注册全局组件局部组件过程解析](https://download.csdn.net/download/weixin_38582506/12934944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值