Vue组件化开发

Vue组件化开发

组件的概念

组件(component)是 Vue 最强大的功能之一,非常重要。
Vue中的组件化开发就是把网页的重复代码抽离出来,分装成一个个可以复用的视图组件,然后将这些视图组件拼接到一块就构成了一个完整的系统。这个方式非常灵活,可以极大的提高我们的开发和维护效果。
在这里插入图片描述
组件系统是一种抽象,允许我们使用小型、独立和通常可复用的组件构建大型应用。简单来说,组件就是对局部视图的封装。

抽离出来的组件,还是有三部分组成,分别是:HTML、JS、CSS。

使用组件的好处,就一句话:提高开发效率,更好的去解决软件上的高耦合、低内聚、无重用的3大代码问题。

组件的基本使用

为了能在模板中使用,这些组件必须先注册以便 Vue 能够识别。
有两种组件注册类型:全局注册局部注册

全局注册

介绍

一般把网页中特殊的公共部分注册为全局的组件:轮播图、分页、通用导航栏等。

全局注册之后,可以在任何新创建的Vue实例的模板中使用。

简单格式:

Vue.component('组件名',{
	template:'定义组件模板',
	data:function(){  // data 选项在组件中必须是一个函数
		return {}
	}
	// 其他选项:methods
})

说明:

  • 组件名:
    可以使用驼峰或者是横线分割命名方式。
    但DOM中只能使用横线分割方式进行引用组件。
    官方强烈推荐组件名字母全小写且必须包含一个连字符
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>全局注册</title>
</head>

<body>


    <div id="app">
        <!-- 引用组件时必须使用横线分割符 -->
        <component-a></component-a>
        <component-a></component-a>
        <component-b></component-b>
    </div>

    <script src="./node_modules/vue/dist/vue.js"></script>

    <script>
        // 全局注册组件
        /***
         * 1.组件命名:驼峰、横线分隔符命名方式
         * 2.使用组件:使用组件时必须采用横线分隔符的方式进行引用
         * 
         * 组件可以理解为就是特殊的Vue实例,不需要手动的实例化而已,它用于管理自己的模板。
         */
        Vue.component('component-a', {
            // template选项,指定组件的模板代码
            template: '<div><h1>头部组件  --  {{name}}</h1></div>',
            data: function () {  // 在组件中,data选项必须是一个函数
                return {
                    name: '全局组件'
                }
            }
        })

        // 定义局部组件对象
        const ComponentB = {
            template: '<div>这是 {{name}} </div>',
            data() {
                return {
                    name: '局部组件'
                }
            },
        }
        new Vue({
            el: '#app',
            components: {
                // key:value   ;  key为组件名,value是组件对象。
                'component-b': ComponentB
            },
            data: {

            }
        })
    </script>

</body>

</html>

在这里插入图片描述

【源码参考】 https://gitee.com/wjw1014/vue_learning

原文地址:https://www.cnblogs.com/wjw1014/p/13391660.html