Vue_qf (7)- 组件

1 虚拟 dom_diff

在这里插入图片描述

  • 把树按照层级分解
    在这里插入图片描述

  • 同 key 值对比
    在这里插入图片描述

  • 同组件对比
    在这里插入图片描述

2 组件

扩展 html 元素,封装可重用的代码

2.1 组件注册方式

  1. 全局组件:Vue.component
  2. 局部组件

2.2 组件编写方式和 Vue 实例的区别

  • 自定义组件需要有一个root element
  • 父子组件的data是无法共享
  • 组件可以有data,methods,computed…,但是data 必须是一个函数

2.2.1 全局组件

<body>
<div id="app">
    <navbar>

    </navbar>
</div>

<script>

    // 1.全局定义组件(作用域隔离)
    Vue.component("navbar", {
        template: `
            <div>
                <button @click="handleHome()">主页</button>
                导航栏
                <button>返回</button>
            </div>
        `,
        methods: {
            handleHome(){
                console.log("返回主页")
            }
        }
    })

    var vm = new Vue({
        el: "#app", // vue 开始渲染的地方
        data: {},
        methods: {},
    })

</script>
</body>

2.2.2 局部组件

在这里插入图片描述

<body>
<div id="app">
    <navbar></navbar>
    <sidebar></sidebar>
</div>

<script>

    // 1.全局定义组件(作用域隔离)
    Vue.component("navbar", {
        template: `
          <div>
          <button @click="handleHome()">主页</button>
          导航栏
          <button>返回</button>

          <child></child>
          <navbarchild></navbarchild>
          </div>
        `,
        methods: {
            handleHome() {
                console.log("返回主页")
            }
        },
        // 局部定义组件
        components: {
            navbarchild: {
                template: `
                    <div> navbarchild组件 - 局部组件,只能在 navbar 组件中使用</div>
                    `
            }
        }
    })

    Vue.component("child", {
        template: `
           <div>child 组件 - 全局定义</div>
        `
    })

    Vue.component("sidebar", {
        template: `
           <div>sidebar 组件 - 全局定义
            <child></child>
           </div>
        `
    })

    var vm = new Vue({ // root Component
        el: "#app",
        data: {},
        methods: {},
    })

</script>
</body>

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值