vue用公共组件页面传值_Vue组件间之间传值实力分析

本文介绍了Vue中组件间的传值技巧,包括父组件向子组件传递数据和子组件向父组件发送事件。通过实例展示了如何实现一个输入框提交内容后显示在页面上,点击内容则消失的功能。关键点在于理解Vue的实例属性和方法,如 `$emit` 用于子组件触发事件。掌握这些技巧对提升Vue应用的开发效率至关重要。
摘要由CSDN通过智能技术生成
43cc29a1cc922635d38e08cf8cceaa01.png

php中文网最新课程

每日17点准时技术干货分享

5730a8a058957e4f3073a7554b92df66.png

c04051c0d94bdbb5a122d69589de64ff.gif

本文为php中文网认证作者:“王雪芹”投稿,欢迎加入php中文网有偿投稿计划!

在我们入门Vue的时候,不得不提到组件,在某些情况下,组件间需要互相传值,比如父组件需要向子组件传值,子组件需要向父组件传值,那么下面用一个实力来详细说明。

效果:

我们想实现这样一个效果,在输入框输入文字点击提交按钮后,下面会出现对应的输入内容。如果点击某个内容,那么这个内容就消失。

如下图,比如我们在点击2的时候,2就会消失

8add357e6e1b334a2d82528c3624baff.png

分析:

1、首先我们会获取到input的输入内容,把所有输入内容都集合成一个数组,在循环数据。因为都是相同的结构,我们可以把做成一个组件,数组是在父层,定义的组件是子组件,这就是父组件向子组件传值,把数据传给子组件。

2、点击某个选项,该选项会消失。那么组件会向上通知父组件,当前点击的是哪个,需要父层的数组数据中哪个去掉,这就是子组件向父组件传值。

<div id="root">                <input v-model="inputValue" />        <button @click="handleSubmit">提交button>                <ul>            <todo-item v-bind:content="item"                        v-bind:index="index"                        v-for="(item,index) in list"                       @delete="handleItemDelete"            >todo-item>        ul>    div>    <script>        var TodoItem={            props:['content','index'],            template:"{{content}}",            methods:{                handleItemClick:function(){                    this.$emit('delete',this.index);                }            }        }        new Vue({            el:"#root",             data:{                inputValue:'',                list:[]            },            components:{                'TodoItem':TodoItem            },            methods:{                handleSubmit:function(){                    this.list.push(this.inputValue)                    this.inputValue = ''  //每次提交后清空                },                handleItemDelete:function(index){                    this.list.splice(index,1);                }            }        })script>

通过代码我们不难发现,子组件向父组件传值主要在这里:

this.$emit('delete',this.index);

另外需要注意到,在Vue中以$开头的都叫做vue的实例属性或者方法,除此之前还需要注意有一些简写,比如提交和提交 是相同的效果。

以上就是Vue组件间之间传值实力分析,升职加薪,大家加油!

7657718a65f7b1cba241a351af272511.png

797555e0af95167fc1381f5da46504f0.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值