首页 > 其他分享 >Vue-组件

Vue-组件

时间:2024-09-17 14:51:16浏览次数:18  
标签:Vue name age template 组件 hello

vue组件 

在 Vue中,组件可以被视为一个独立的 Vue 实例,具有其自己的数据、模板和方法,可以独立处理其内部逻辑,与其他组件和 Vue 实例进行交互。

非单文件组件

非单文件组件是指一个文件中包含多个vue组件

非单文件组件的使用

Vue中使用组件的三大步骤:

一、定义组件(创建组件)

使用Vue.extend(options)创建,其中options和new Vue(options)时传入的那个options几乎一样,但也有区别,区别如下:
1.el不要写 ——— 最终所有的组件都要经过一个vm的管理,由vm中的el决定服务哪个容器。
2.data必须写成函数 ———— 避免组件被复用时,数据存在引用关系。
注:使用template可以配置组件结构。

二、注册组件

1.局部注册:靠new Vue的时候传入components选项
2.全局注册:靠Vue.component('组件名',组件)

三、使用组件(写组件标签)

<brother1></brother2>

<brother2></brother2>

代码示例:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./js/vue.js"></script>
</head>
<body>
    <div id="root">
        <!-- 编辑组件标签brother1 -->
        <brother1></brother1>
        <hr>
        <!-- 编辑组件标签brother2 -->
        <brother2></brother2>
     </div>
</body>

      <script>
        Vue.config.productionTip = false
        Vue.config.devtools = true
        //创建brother1组件
        const brother1 = Vue.extend({
            template:`
              <div>
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p>
             <button @click="add">点我加一{{n}}</button>
        </div>
            `,
            data(){
                return {
                    n:1,
                    name:'小明',
                    age:18
                }
            },
            methods: {
                add(){
                    this.n++
                }
            },
        })
        //创建brother2组件
        const brother2 = Vue.extend({
            template:`
              <div>
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p>
        </div>
            `,
            data(){
                return {
                    name:'小亮',
                    age:19
                }
            }
        })

        //局部注册组件(此处注册组件的方式为局部注册)
        // new Vue({
        //     el:'#root',
        //     data:{

        //     },
        //     components:{
        //     brother1,
        //     brother2
        // }
        // })
        //全局注册组件
        Vue.component('brother1',brother1)
        Vue.component('brother2',brother2)
        new Vue({
            el:'#root'
        })
      </script>
</html>

运行截图:

注意事项 

1.关于组件名:

一个单词组成: 第一种写法(首字母小写):brother1

第二种写法(首字母大写):Brother1 

多个单词组成:

第一种写法(kebab-case命名):my-school

第二种写法(CamelCase命名即大驼峰命名法):MyBrother(需要Vue脚手架支持)

注:

(1).组件名尽可能回避HTML中已有的元素名称,例如:p与P都不行。  

(2).可以使用name配置项指定组件在开发者工具中呈现的名字。

  const brother1 = Vue.extend({
            name:'brother',//配置在vue开发工具中呈现的名字
            template:`
              <div>
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p>
             <button @click="add">点我加一{{n}}</button>
        </div>
            `,
            data(){
                return {
                    n:1,
                    name:'小明',
                    age:18
                }
            },
            methods: {
                add(){
                    this.n++
                }
            },
        })

 在开发者工具中:

2.关于组件标签:
第一种写法:<brother></brother>
第二种写法:</brother>
注:

不用使用脚手架时,</brother>会导致后续组件不能渲染,即有多个</brother>组件标签时,只会渲染一个</brother>。

3.一个简写方式:const brother= Vue.extend(options) 可简写为:const brother= options

4.template可以配置组件结构,但需要有根节点,可以在外层使用div作为根节点,且template不能作为根节点。

 
template:`
              <div>
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p>
             <button @click="add">点我加一{{n}}</button>
        </div>  
            `      //不会报错
template:`
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p>
             <button @click="add">点我加一{{n}}</button>
            `        //会报错,缺乏根节点
template:`
            <p>我是{{name}}</p>
            <p>我{{age}}岁</p><button @click="add">点我加一{{n}}</button>
            `        //会报错,有两个根节点,意思是p与button写一行了
 

组件嵌套

组件嵌套:将一个组件放置在另一个组件内部。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./js/vue.js"></script>
</head>

<body>
    <div id="root">
        <!-- 编辑组件标签 -->
        <father></father>
        <hello></hello>
        <hr>

    </div>
</body>
<script>
    Vue.config.productionTip = false
    Vue.config.devtools = true
    // 创建son组件
    const son = Vue.extend({
        template: `
             <div>
            <p>我是{{erzi}}</p>
            <p>我{{age}}岁</p>
         </div>
            `,
        data() {
            return {
                erzi: '儿子',
                age: 18
            }
        },
    })
    //创建father组件
    const father = Vue.extend({
        template: `
             <div>
            <p>我是{{baba}}</p>
            <p>我{{age}}岁</p>
            <hr>
            <son></son>
         </div>
            `,
        data() {
            return {
                baba: '爸爸',
                age: 45
            }
        },
        //局部注册son组件
        components: {
            son,
        }
    })
    // 创建hello组件
    const hello = Vue.extend({
        template: `
             <div>
            <p>{{hello}}</p>
            <p>{{info}}</p>
            <button @click="showInfo">点我提示信息</button>
         </div>
            `,
        data() {
            return {
                hello: '你好',
                info: '世界'
            }
        },
        methods: {
            showInfo() {
                alert(this.hello)
            }
        }
    })
    //创建app组件
    const app = Vue.extend({
        template: `
             <div>
            <father></father>
            <hr>
            <hello></hello>
         </div>
            `,
        //注册father与hello组件
        components: {
            father,
            hello
        }
    })
    //注册app组件
    const vm=new Vue({
        template: `
            <app></app>
            `,
        el: '#root',
        components: {
            app,
        }
    })
</script>

</html>

VueComponent     

VueComponent 是 Vue框架中的一个核心概念,指的是一个 Vue 组件的实例。当你创建一个 Vue 组件的实例时,Vue 会返回一个 VueComponent 实例。这个实例是一个包含组件状态和方法的对象。        

关于VueComponent:

1.上面代码示例中的hello组件本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的。

 2.我们只需要写<hello/>或<hello></hello>,Vue解析时会帮我们创建school组件的实例对象,即Vue帮我们执行的:new VueComponent(options)。

 3.特别注意:每次调用Vue.extend,返回的都是一个全新的VueComponent!!!!

 4.关于this指向:
(1).组件配置中:data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【VueComponent实例对象】。
(2).new Vue(options)配置中:data函数、methods中的函数、watch中的函数、computed中的函数 它们的this均是【Vue实例对象】。

5.Vue实例对象与VueComponent组件对象是一种管理的关系。

上述代码案例中控制台输入vm,可以看到vm实例下存在$children。

一个重要的内置关系       

1.一个重要的内置关系:VueComponent.prototype.__proto__ === Vue.prototype

2.为什么要有这个关系:让组件实例对象(VueComponent)可以访问到 Vue原型上的属性、方法。  

3.原理图:

下面通过代码验证这个内置关系。    

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script type="text/javascript" src="./js/vue.js"></script>
</head>
<body>
    <div id="root">
         <hello></hello>
    </div>
</body>
    <script>
        Vue.config.productionTip = false
        Vue.config.devtools = true
        Vue.prototype.info='hello world!'

            // 创建hello组件
    const hello = Vue.extend({
        template: `
             <div>
            <p>{{hello}}</p>
            <p>{{world}}</p>
            <button @click="showInfo">点我提示信息</button>
         </div>
            `,
        data() {
            return {
                hello: '你好',
                world: '世界'
            }
        },
        methods: {
            showInfo() {
                console.log(this.info)   //验证是否可以访问沿原型链访问到vue原型对象中的info
            }
        }
    })

     new Vue({
            el:'#root',
            components:{
                hello,
            }
        })
    console.log(hello.prototype.__proto__ === Vue.prototype)  //验证这个内置关系是否成立
//         //定义一个构造函数
//         function Persons(name,age){
//             this.name = name,
//             this.age = age
// }       
//           const p = new Persons('小明',18)

//           console.log(Persons.prototype)  //显示原型属性

//           console.log(p.__proto__)   //隐式原型属性

//           console.log(Persons.prototype === p.__proto__)

//           Persons.prototype.age = 20
//           console.log('即将输出p')
//           console.log(p)
      
    </script>
</html>

  控制台输出可以验证VueComponent.prototype.__proto__ === Vue.prototype

 单文件组件

单文件组件:指一个文件中只包含一个vue组件。将组件的模板、脚本和样式集中在一个文件中进行管理。通常以 .vue 后缀命名。

一个典型的单文件组件会包含以下三个部分:

  1. 模板(Template):用于定义组件的 HTML 结构。
  2. 脚本(Script):包含组件的逻辑代码,如数据、方法、生命周期钩子等。
  3. 样式(Style):用于定义组件的 CSS 样式,可以是全局样式或者局部样式。

单文件组件的好处包括:

  • 模块化:将相关代码放在一起,更易于维护和理解。
  • 可重用性:组件可以被重复使用,提高开发效率。
  • 更好的工作流:通过构建工具(如 Webpack)可以方便地处理组件的编译、热重载等功能。

下面通过一个里】例子演示单文件组件的创建过程 

①先分别创建Brother.vue和Sister.vue

<template>
	<div class="demo">
		<h2>名字:{{name}}</h2>
		<h2>年龄:{{age}}</h2>
        <h2>性别:{{sex}}</h2>
		<button @click="showName">点我显示名字</button>	
	</div>
</template>

<script>
	 export default {
		name:'Brother',
		data(){
			return {
				name:'小明',
				age:18,
                sex:'男'
			}
		},
		methods: {
			showName(){
				alert(this.name)
			}
		},
	}
</script>

<style>
	.demo{
		background-color: blue;
	}
</style>

Sister.vue

<template>
	<div class="demo">
		<h2>名字:{{name}}</h2>
		<h2>年龄:{{age}}</h2>
        <h2>性别:{{sex}}</h2>
		<button @click="showName">点我显示名字</button>	
        <hr></hr>
	</div>
</template>

<script>
	 export default {
		name:'Sister',
		data(){
			return {
				name:'小红',
				age:18,
                sex:'女'
			}
		},
		methods: {
			showName(){
				alert(this.name)
			}
		},
	}
</script>

<style>
	.demo{
		background-color: orange;
	}
</style>

创建全局组件App.vue注册Brother组件和Sister组件。

<template>
	<div>
		<Brother></Brother>
		<Sister></Sister>
	</div>
</template>

<script>
	//引入组件
	import Brother from './Brother.vue'
	import Sister from './Sister.vue'

	export default {
		name:'App',
		components:{
			Brother,
			Sister
		}
	}
</script>

在项目的入口文件中main.js注册全局组件App

import App from './App.vue'

new Vue({
	el:'#root',
	template:`<App></App>`,
	components:{App},
})

在index.html使用

<!DOCTYPE html>

<html>

	<head>

		<meta charset="UTF-8" />

		<title>demo</title>

	</head>

	<body>

		<div id="root"></div>

		<!-- <script type="text/javascript" src="../js/vue.js"></script> -->

		<!-- <script type="text/javascript" src="./main.js"></script> -->

	</body>

</html>

标签:Vue,name,age,template,组件,hello
From: https://blog.csdn.net/m0_63563047/article/details/142102556

相关文章

  • VUE框架CLI组件化组件解绑事件实现------VUE框架
    <template> <div> <!--内置函数的实现步骤--> <!--提供事件源,给事件源绑定事件,编写回调函数,将回调函数和事件进行绑定--> <!--等待事件的触发,事件触发执行回调函数--> <!--组件的自定义事件实现步骤--> <button@click="Hello()">你好</button> <!--给Us......
  • 基于django+vue高校毕业论文管理系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着高等教育规模的持续扩大,毕业论文作为衡量学生综合素质与专业能力的重要环节,其管理工作日益复杂。传统的手工管理方式已难以满足当前高......
  • 【开题报告】基于django+vue网上购物商城系统(论文+程序)
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着互联网技术的飞速发展,电子商务已成为现代商业活动不可或缺的一部分,极大地改变了人们的购物方式和消费习惯。网上购物商城作为电子商务......
  • 基于django+vue高校毕业班校务管理系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着高等教育规模的不断扩大,高校毕业班管理面临着前所未有的挑战。传统的手工管理方式已难以满足当前复杂多变的校务管理需求,特别是在学生......
  • 基于django+vue高校笔记分享系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景在信息化高速发展的今天,高等教育领域正经历着前所未有的变革。随着知识更新速度的加快和在线学习平台的兴起,学生们对于高效获取、整理与分......
  • 基于django+vue高校班级事务管理系统【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着高等教育规模的不断扩大与信息技术的飞速发展,高校班级管理面临着前所未有的挑战。传统的手工记录、口头传达等管理方式已难以满足日益......
  • Leetcode 952. 按公因数计算最大组件大小
    1.题目基本信息1.1.题目描述给定一个由不同正整数的组成的非空数组nums,考虑下面的图:有nums.length个节点,按从nums[0]到nums[nums.length-1]标记;只有当nums[i]和nums[j]共用一个大于1的公因数时,nums[i]和nums[j]之间才有一条边。返回图中最大连通组件的大小......
  • springboot+vue智能家居项目管理系统【程序+论文+开题】计算机毕业设计
    系统程序文件列表开题报告内容研究背景随着物联网、云计算、大数据等技术的飞速发展,智能家居行业正经历着前所未有的变革与增长。智能家居产品以其便捷性、智能化和高效能的特点,逐渐渗透到人们的日常生活中,成为现代家庭追求高品质生活的重要标志。然而,智能家居项目的实施涉......
  • springboot+vue在线药店管理系统【程序+论文+开题】计算机毕业设计
    系统程序文件列表开题报告内容研究背景随着互联网的飞速发展,电子商务已经渗透到人们生活的方方面面,医疗健康领域也不例外。传统药店面临着运营成本高、顾客覆盖面有限、药品管理繁琐等挑战。特别是在疫情期间,人们对于安全、便捷的药品购买方式需求激增,推动了在线药店的快速......
  • springboot+vue一体化智能售后系统【程序+论文+开题】计算机毕业设计
    系统程序文件列表开题报告内容研究背景在当今数字化时代,随着产品种类与消费者需求的日益多样化,售后服务作为提升客户满意度与品牌忠诚度的重要环节,其效率与智能化水平直接关系到企业的市场竞争力。传统的售后系统往往存在信息孤岛、流程繁琐、响应滞后等问题,难以适应快速变......