Vue组件间之间传值实力分析

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

效果:

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

分析:

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组件间之间传值实力分析的详细内容,更多内容请关注技术你好其它相关文章!

来源链接:
免责声明:
1.资讯内容不构成投资建议,投资者应独立决策并自行承担风险
2.本文版权归属原作所有,仅代表作者本人观点,不代表本站的观点或立场
标签: Vue组件
上一篇:php获取远程图片并下载保存到本地的方法分析 下一篇:json数据是什么

相关资讯