首页 > 其他 > 详细

Vue父子之间的值传递

时间:2020-07-01 21:03:23      阅读:36      评论:0      收藏:0      [点我收藏+]

将通过两个input框实现父子之间的值传递作为演示,效果图

技术分享图片

先注册父子各一个组件,代码如下

 

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

    <template id="parent">
        <div>
            <input type="text" v-model="text" placeholder="parent">
            <son></son>
        </div>
    </template>
    <template id="son">
        <div>
            <input type="text" placeholder="son">
        </div>
    </template>
 new Vue({
        el: "#app",
        components: {
            parent: {
                template: ‘#parent‘,
                data() {
                    return {
                        text: ‘‘
                    }
                },
                components: {
                    son: {
                        template: ‘#son‘
                    }
                }
            }
        }
    })

技术分享图片

 

 一、父传子

再父组件通过属性传递值

 <template id="parent">
        <div>
            <input type="text" v-model="text" placeholder="parent">
            <son :text="text"></son>//通过属性值传递
        </div>
    </template>

子组件通过props属性接受

 components: {
                    son: {
                        template: ‘#son‘,
                        props:[‘text‘] //通过props属性接受父传递过来的值
                    }
                }

这样我们就可以使用父组件传递过来的值了

 <template id="son">
        <div>
            <input type="text" placeholder="son" :value="text">//使用父元素传递过来的值
        </div>
    </template>

看下现在的效果

技术分享图片

父组件向子组件传递成功

二、子传父

通过父组件自定义事件,然后子组件用$emit(event,aguments)调用

 <template id="parent">
        <div>
            <input type="text" v-model="text" placeholder="parent">
            <son :text="text" @ev="item"></son>//自定义事件
        </div>
    </template>


components: {
            parent: {
                template: ‘#parent‘,
                data() {
                    return {
                        text: ‘‘
                    }
                },
                components: {
                    son: {
                        template: ‘#son‘,
                        props: [‘text‘]
                    }
                },
                methods: {
                    item(v) { //自定义事件触发的方法
                        this.text = v //使用子组件传递过来的值改变this.text数据
                    }
                }
            }
        }

再子组件触发自定义事件

<template id="son">
        <div>
            <input type="text" placeholder="son" :value="text" @input="emit" ref="son">//触发自定义事件
        </div>
    </template>



components: {
            parent: {
                template: ‘#parent‘,
                data() {
                    return {
                        text: ‘‘
                    }
                },
                components: {
                    son: {
                        template: ‘#son‘,
                        props: [‘text‘], 
                        methods: {
                            emit() {
                                this.$emit(‘ev‘, this.$refs.son.value) //触发自定义事件,并传递值
                            }
                        }
                    }
                },
                methods: {
                    item(v) {
                        this.text = v
                    }
                }
            }
        }

这样就完成了子传父,父传子,效果也完成了

Vue父子之间的值传递

原文:https://www.cnblogs.com/zlf1914/p/13221367.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!