Vue第四天(父子组件间通信 ref 获取 DOM 元素和组件 路由)

本文详细介绍了Vue中父子组件间的通信,包括如何从父组件向子组件传值及子组件向父组件传值。还探讨了`ref`的使用,展示了如何获取DOM元素和组件实例。此外,文章还深入讲解了Vue路由的基本概念,包括前端路由的工作原理,并通过实例演示了路由规则中定义参数、路由的嵌套和命名视图的经典布局实现。
摘要由CSDN通过智能技术生成

Vue第四天

父子组件间通信

ref 获取 DOM 元素 和 组件

路由

父组件向子组件传值

1.子组件使用父组件中的数据
  • 初步尝试—(错误分析)

mark

  • 正确使用方法
<div id="app">
    <!--父组件,可以在引用子组件的时候,通过 属性绑定(v-bind:) 的形式,把需要 传递给子组件 的数据,以属性绑定的形式,传递到子组件内部,供子组件使用-->
    <com1 v-bind:parentmsg="msg"></com1>
</div>
<script>
    let vm = new Vue({
    
        el: '#app',
        data: {
    
            msg: '123 父组件中的数据'
        },
        methods: {
    },
        components: {
    
            com1: {
    
                //props中的数据,都是只读的,无法重新赋值。
                props: ['parentmsg'],//把父组件传递过来的 parentmsg 属性,先在 props 数组中,先定义一下,这样才能使用这个数据
                template: '<h1>这是子组件---{
    {parentmsg}}</h1>'
            }
        }
    })
</script>

mark

2.子组件使用父组件中的方法
<div id="app">
    <com1 @func="show"></com1>
</div>

<template id="tmp1">
    <div>
        <h1>这是子组件</h1>
        <button @click="myclick">这是子组件的中的按钮</button>
    </div>
</template>
<script>
    let com2 = {
    
        template: '#tmp1',
        methods: {
    
            myclick() {
    
                //  emit 英文原意:是触发,调用,发射的意思
                this.$emit('func')
            }
        }
    }

    let vm = new Vue({
    
        el: '#app',
        data: {
    },
        methods: {
    
            show() {
    
                console.log('调用父组件身上的show方法')
            }
        },
        components: {
    
            com1: com2
        }
    })
</script>

mark

子组件向父组件传值

  • 设置参数( 供子组件传递参数 )

mark

mark

  • 列举 list 数据对象 说明
<div id="app">
    <com1 @func="show"></com1>
</div>

<template id="tmp1">
    <div>
        <h1>这是子组件</h1>
        <button @click="myclick">这是子组件的中的按钮</button>
    </div>
</template>

<script>
    let com2 = {
    
        template: '#tmp1',
        data () {
    
            return {
    
                list: [{
    'id': '1', 'age': '18'}]
            }
        },
        methods: {
    
            myclick() {
    
                // emit 英文原意:是触发,调用,发射的意思
                this.$emit('func', this.list)
            }
        }
    }

    let vm = new Vue({
    
        el: '#app',
        data: {
    },
        methods: {
    
            show(data) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值