首页 > web前端 > js教程 > 正文

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

王雪芹
发布: 2020-08-11 18:08:49
原创
1534人浏览过

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

效果:

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

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

微信截图_20200811180017.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:"<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的实例属性或者方法,除此之前还需要注意有一些简写,比如 > 是相同的效果。

    相关推荐:《javascript高级教程

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

  • 以上就是Vue组件间之间传值实力分析的详细内容,更多请关注php中文网其它相关文章!

    最佳 Windows 性能的顶级免费优化软件
    最佳 Windows 性能的顶级免费优化软件

    每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

    下载
    来源:php中文网
    本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
    最新问题
    开源免费商场系统广告
    热门教程
    更多>
    最新下载
    更多>
    网站特效
    网站源码
    网站素材
    前端模板
    关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送
    PHP中文网APP
    随时随地碎片化学习
    PHP中文网抖音号
    发现有趣的

    Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号