首页 > 其他分享 >组件嵌套以及VueComponent的讲解(代码实现)

组件嵌套以及VueComponent的讲解(代码实现)

时间:2022-12-12 17:35:08浏览次数:50  
标签:Vue extend VueComponent 嵌套 实例 组件 data

1、效果图分析

在这里插入图片描述

2、先创建一个组件

    //第一步、创建city组件
        const city = Vue.extend({
            template: `
                <div class="cityDemo">
                     城市名称:{{cityName}}
                     城市美食:{{cityFood}}
                     <button @click="show">点击我弹窗</button>
                 </div>
            
            `,
            data() {
                return {
                    cityName: "周口",
                    cityFood: "胡辣汤"
                }

            },
            methods: {
                show() {
                    alert("你好啊、Vue")
                }
            },
        })

3、新创建一个组件、嵌套已经存在的组件

==注意:注册组件的过程写在新组建中。并且在template中要使用组件才可以生效==

        //第一步创建 学校组件
        const school = Vue.extend({
            name: "myschoolOne",
            template: `
                <div class="cityDemo">
                     学校名称:{{schoolName}}
                     学校位置:{{schoolAddress}} 
                     <city></city>    
                 </div>
            
            `,
            data() {
                return {
                    schoolName: "长沙大学",
                    schoolAddress: "湖南长沙"

                }
            },
            //2、注册组件
            components: {
                city
            }


        })

4、第四步 注册组件

     //创建Vue实例
        new Vue({
            el: '#App',
            data: {
                value: "Vue"
            },
            //第二步、注册组件(局部注册)
            components: {
                school
            }
        })

5、实现的效果

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

6、套娃式嵌套 代码实例

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8" />
    <title>标题</title>
    <!-- 引入vue -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>

<body>

    <div id="App">
        <app></app>

    </div>


    <script type="text/javascript">
        Vue.config.productionTip = false  //设置为 false 以阻止 vue 在启动时生成生产提示

        //第一步、创建city组件
        const city = Vue.extend({
            template: `
                <div class="cityDemo">
                     城市名称:{{cityName}}
                     城市美食:{{cityFood}}
                     <button @click="show">点击我弹窗</button>
                 </div>
            
            `,
            data() {
                return {
                    cityName: "周口",
                    cityFood: "胡辣汤"
                }

            },
            methods: {
                show() {
                    alert("你好啊、Vue")
                }
            },
        })

        //第一步创建 学校组件
        const school = Vue.extend({
            name: "myschoolOne",
            template: `
                <div class="cityDemo">
                     学校名称:{{schoolName}}
                     学校位置:{{schoolAddress}} 
                     <city></city>    
                 </div>
            
            `,
            data() {
                return {
                    schoolName: "长沙大学",
                    schoolAddress: "湖南长沙"

                }
            },
            //2、注册组件
            components: {
                city
            }


        })


        //第一步创建学生组件
        const student = Vue.extend({
            name: "student",
            template: `
                <div class="studentDemo">
                     学生姓名:{{studentName}}
                     学生年龄:{{studentAge}}  
                 </div>
            `,
            data() {
                return {
                    studentName: 'zyz',
                    studentAge: 18
                }
            }

        })

        //定义App组件
        const app = Vue.extend({
            template: `
                <div>
                    <school></school>
                    <student></student>
                 </div> 
            `,
            components: {
                school,
                student
            }
        })

        // 第二步、全局注册组件
        // Vue.component('city', city)

        //创建Vue实例
        new Vue({
            el: '#App',
            data: {
                value: "Vue"
            },
            //第二步、注册组件(局部注册)
            components: {
                app
            }
        })


    </script>

</body>

</html>

7、测试效果

在这里插入图片描述

8、关于VueComponent

关于VueComponent:

  • 1、==school组件==本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的。

  • 2、我们只需要写<school/><school></school>,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、VueComponent的实例对象,以后简称vc(也可称之为:组件实例对象)。 Vue的实例对象,以后简称vm。

9、代码实例

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8" />
    <title>标题</title>
    <!-- 引入vue -->
    <script type="text/javascript" src="../js/vue.js"></script>
</head>

<body>

    <div id="App">
        展示的信息:{{name}}
        <button @click="fun()">请点击我Vue</button>
        <hr>
        <!-- 第三步、编写组件标签 -->
        <school></school>
    </div>


    <script type="text/javascript">
        Vue.config.productionTip = false  //设置为 false 以阻止 vue 在启动时生成生产提示


        //第一步创建 学校组件
        const school = Vue.extend({
            name: "myschoolOne",
            template: `
                <div class="cityDemo">
                     学校名称:{{schoolName}}
                     学校位置:{{schoolAddress}}
                     <button @click="show">点击我弹窗</button>     
                 </div>
            
            `,
            data() {
                return {
                    schoolName: "长沙大学",
                    schoolAddress: "湖南长沙"

                }
            },
            methods: {
                show() {
                    console.log("我是VueComponent", this)
                }
            },


        })



        //创建Vue实例
        new Vue({
            el: '#App',
            data: {
                name: "你好,VUE"
            },
            methods: {
                fun() {
                    console.log("我是Vue", this)
                }
            },
            //第二步、注册组件(局部注册)
            components: {
                school
            }
        })


    </script>

</body>

</html>

10、实现的效果

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

在这里插入图片描述

标签:Vue,extend,VueComponent,嵌套,实例,组件,data
From: https://blog.51cto.com/u_15740728/5931207

相关文章

  • HarmonyOS实战一【JS基础组件】switch、chart等的使用
    写在前面嗯,有这样一个活动,所以搞了一个小Demo,顺便学习一个js的鸿蒙的开发方式,感兴趣的小伙伴积极参与,活动地址:HarmonyOS线上Codelabs系列挑战赛博文主要是一些前端组件使......
  • froms组件
    目录校验性组件:froms组件1、前戏2、基本使用3、校验数据4、渲染标签4.1、先在后端生成一个空对象4.2、第一种渲染方式4.3、第二种渲染方式4.4、第三种渲染方式5、展示错误......
  • Django自带的序列化组件
    Django自带的序列化组件(为drf做铺垫)(drf:djangorestframework)#在前端获取到,后端用户表里所有的数据,并且是列表套字典的格式#views.pyfromdjango.httpimport......
  • 解决mybatis一对多嵌套查询,解决分页数据少了的问题
    转载自:https://blog.csdn.net/zjun1001/article/details/117671517 问题在用mybatis做一对多查询时候,常用collection配合完成结果查询。在不涉及分页查询情况下,查询结果......
  • 「Vue系列」之Vue2实现当前组件重新加载
     遇到问题的场景:需要把当前组件完全还原成初始化状态,不要页面全部刷新例如:重置按钮,只刷新当前加载组件其他办法:使用vue-router重新定向到当前页面,页面不刷新使用window-r......
  • vue3 封装t点击左右箭头实现内容滑动组件
    1、组件<template><divclass="switch-tab"><divclass="switch-tab-left"@click="leftClick"><el-icon:size="24"color="rgba(99,149,255,1)"><A......
  • react组件深度解读
    五、React核心是组件在React中,我们使用组件(有状态、可组合、可重用)来描述UI。在任何编程语言中,你都可以将组件视为简单的函数。React组件也一样,它的输入是props......
  • 前端开发系列052-基础篇之数据流和组件通信(Vue)
    title:前端开发系列052-基础篇之数据流和组件通信(Vue)tags:categories:[]date:2017-12-2100:00:00本文是早期学习Vue整理的一些阶段性总结,内容主要关于Vue框架......
  • 前端开发系列050-基础篇之组件的概念和使用(Vue)
    title:'前端开发系列050-基础篇之组件的概念和使用(Vue)'tags:categories:[]date:2017-12-0901:00:00本文是早期学习Vue整理的一些阶段性总结,内容主要关于Vue框......
  • React组件之间的通信方式总结(下)
    一、写一个时钟用react写一个每秒都可以更新一次的时钟importReactfrom'react'importReactDOMfrom'react-dom'functiontick(){letele=<h1>{ne......