VueComponent

关于VueComponent

1.school组件本质是一个名为VueComponent的构造函数,且不是程序员定义的,是Vue.extend生成的。
2.我们只需要写或,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。
6.一个重要的内置关系:VueComponent.prototype.proto=== Vue.prototype
为什么要有这个关系:让组件实例对象(vc)可以访问到Vue原型上的属性、方法。

<body>
    <div id="root">

        

    </div>
    <script>
        Vue.prototype.x = 99

        const student = Vue.extend({
            template: `
                <div>
                    <h3>学生名称:{{name}}</h3>
                    <h3>学生年龄:{{age}}</h3>
                </div>
            `,
            data() {
                return {
                    name: "张三",
                    age: 18,
                }
            }
        })

        const school = Vue.extend({
            template: `
                <div>
                    <h3>学校名称:{{name}}</h3>
                    <h3>学校地址:{{address}}</h3>
                    <button @click="tip">点我一下显示this</button>
                    <student></student>
                    
                </div>
               
            `,
            data() {
                return {
                    name: "尚硅谷",
                    address: "北京昌平",
                }
            },
            components:{
                student,
            },
            methods: {
                tip(){
                    console.log("显示school的this为",this)
                    console.log("组件实例上的x",this.x)
                }
            }
        })

        const hello = Vue.extend({
            template: `
                <div>
                    <h3>你好啊{{name}}!</h3>
                </div>
            `,
            data(){
                return {
                    name: "Tom",
                }
            }
        })

        const app = Vue.extend({
            template:`
                <div>
                    <school></school>
                    <hello></hello>
                </div>
            `,
            components: {
                school,
                hello,
            },
        })

        const vm = new Vue({
            el: "#root",
            template:`
                <app></app>
            `,
            components: {
                app,
            }
        })

    </script>
</body>

在Vue原型上定义属性x为99,组件实例化对象也能访问
在这里插入图片描述

APP替root管理组件,Vue开发者工具父件子件架构。

这里是引用

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值