效果:
我们想实现这样一个效果,在输入框输入文字点击提交按钮后,下面会出现对应的输入内容。如果点击某个内容,那么这个内容就消失。
如下图,比如我们在点击2的时候,2就会消失
分析:
1、首先我们会获取到input的输入内容,把所有输入内容都集合成一个数组,在<li><li>循环数据。因为<li><li>都是相同的结构,我们可以把<li><li>做成一个组件,数组是在父层,定义的<li><li>组件是子组件,这就是父组件向子组件传值,把数据传给子组件。
2、点击<li><li>某个选项,该选项会消失。那么<li><li>组件会向上通知父组件,当前点击的是哪个,需要父层的数组数据中哪个去掉,这就是子组件向父组件传值。
<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:"<li @click='handleItemClick'>{{content}}</li>", 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的实例属性或者方法,除此之前还需要注意有一些简写,比如<button v-on="handleSubmit">提交</button>和<button @click='handleSubmit'>提交</button > 是相同的效果。
相关推荐:《javascript高级教程》
以上就是Vue组件间之间传值实力分析,升职加薪,大家加油!
以上就是Vue组件间之间传值实力分析的详细内容,更多请关注php中文网其它相关文章!
![php中文网最新课程二维码](/static/images/article_wechat2021.jpg?1111)
声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
- 上一篇:json数据是什么
- 下一篇:深入研究Node.js中的日志信息
网友评论
文明上网理性发言,请遵守 新闻评论服务协议
我要评论