Vue学习之--------组件嵌套以及VueComponent的讲解(代码实现)(2022/7/23)

简介: 这篇文章通过代码示例和效果图,详细阐述了Vue中组件的嵌套使用,包括创建组件、组件间的嵌套、注册组件以及实现的效果。同时,文章还介绍了VueComponent的相关知识,包括组件实例对象和Vue实例对象的区别。

欢迎加入刚建立的社区:http://t.csdn.cn/Q52km
加入社区的好处:
1、专栏更加明确、便于学习
2、覆盖的知识点更多、便于发散学习
3、大家共同学习进步
3、不定时的发现金红包(不多哈)

文章目录

  • 1、效果图分析
  • 2、先创建一个组件
  • 3、新创建一个组件、嵌套已经存在的组件
  • 4、第四步 注册组件
  • 5、实现的效果
  • 6、套娃式嵌套 代码实例
  • 7、测试效果
  • 8、关于VueComponent
  • 9、代码实例
  • 10、实现的效果

1、效果图分析

在这里插入图片描述

2、先创建一个组件

    //第一步、创建city组件
        const city = Vue.extend({
            template: `
                <div class="cityDemo">
                     <h1>城市名称:{
  
  {cityName}}</h1>
                     <h1>城市美食:{
  
  {cityFood}}</h1>
                     <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">
                     <h1>学校名称:{
  
  {schoolName}}</h1>
                     <h1>学校位置:{
  
  {schoolAddress}}</h1> 
                     <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">
                     <h1>城市名称:{
  
  {cityName}}</h1>
                     <h1>城市美食:{
  
  {cityFood}}</h1>
                     <button @click="show">点击我弹窗</button>
                 </div>

            `,
            data() {
                return {
                    cityName: "周口",
                    cityFood: "胡辣汤"
                }

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

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

            `,
            data() {
                return {
                    schoolName: "长沙大学",
                    schoolAddress: "湖南长沙"

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

        })

        //第一步创建学生组件
        const student = Vue.extend({
            name: "student",
            template: `
                <div class="studentDemo">
                     <h1>学生姓名:{
  
  {studentName}}</h1>
                     <h1>学生年龄:{
  
  {studentAge}}</h1>  
                 </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">
        <h1>展示的信息:{
  
  {name}}</h1>
        <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">
                     <h1>学校名称:{
  
  {schoolName}}</h1>
                     <h1>学校位置:{
  
  {schoolAddress}}</h1>
                     <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、实现的效果

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

在这里插入图片描述

相关文章
|
17天前
|
移动开发 JavaScript API
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
17天前
|
JavaScript 前端开发 开发者
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
|
17天前
|
JavaScript 前端开发 数据安全/隐私保护
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。
|
JavaScript
Vue的非父子组件之间传值
全局事件总线 一种组件间通信的方式,适用于任意组件间通信
100 0
|
缓存 JavaScript 前端开发
Vue Props、Slot、v-once、非父子组件间的传值....
Vue Props、Slot、v-once、非父子组件间的传值....
105 0
|
JavaScript
Vue中父子组件传值
先在⽗组件中给⼦组件的⾃定义属性绑定⼀个⽗组件的变量
102 0
|
JavaScript
vue 组件传值
vue 组件传值
98 0
|
JavaScript
vue父子组件传值
vue父子组件传值
|
JavaScript
vue兄弟组件传值 方便快捷
vue兄弟组件传值 方便快捷
|
JavaScript
Vue父子组件传值(porvide+inject实现组件通信)
如果我们需要把父组件的值传递给子组件,而且子组件可能存在层层嵌套,那么就可以使用provide+inject的方法来实现组件之间的通信
203 0
Vue父子组件传值(porvide+inject实现组件通信)

热门文章

最新文章