三、组件与实例的关系,组件间怎么发生通信(父组件向子组件传值)

每一个Vue的组件都是一个Vue的实例,像实例一样,组件里也可以有template实例,也可以有methods等等。我们以后就统说成实例或者是组件。

组件与组件间怎么发生通信呢?
依然沿用上面的例子,做一个需求:当点击li标签的时候,弹出一个“clicked”的弹框,用全局组件编写这个需求。

body>
    <div id="root">
        <div>
            <input v-model="inputValue" />
            <button @click="handleSubmit">提交</button>
        </div>
        <ul>
            <todo-item
            v-for="(item, index) of list"
            :key="index"
            :content="item"
            >
            </todo-item>
        </ul>
    </div>
    
    <script>
        Vue.component('todo-item',{
            props:['content'],
            template:'<li @click="handleClick">{{content}}</li>',
            methods: {
                handleClick: function(){
                    alert('clicked')
                }
            }
        })
        new Vue({
            el:"#root",
            data:{
                inputValue:'hello',
                list:[]
            },
            methods:{
                handleSubmit:function(){
                    this.list.push(this.inputValue)
                    this.inputValue =''
                }
            }
        })
    </script>
</body>

浏览器中,点击提交,点击li标签的内容后,会出来一个“clicked”的弹框:


image.png

这个代码里面有一个Vue实例和一个Vue全局组件。
Vue实例创建了输入框内的hello和空的list项,还创建了一个handleSubmit方法,该方法在点击提交后,把在输入框中的内容导进了list项中,然后抹掉了输入框中的数据。
Vue组件创建了一个名叫todo-item全局组件,该组件创建了一个li标签和一个handleClick方法,该方法是在点击li标签内容的时候,弹出一个clicked的弹窗。

这样就出现了一个问题,在Vue实例中创建的list数组中的项,这些项会在Vue组件中的li标签中显示出来,但这个项怎么传达到Vue组件当中?
可以认为Vue实例是一个父组件,component是一个子组件,在ul标签内,item将数据传给了content属性,在子组件中,通过props接收了content属性的内容,然后在子组件中的模板中显示出来。
所以在ul标签中todo-item实现了从父组件中的值传给某一个属性,然后这个属性传给了子组件,这样形成了父组件向子组件的数据传递。
有一点需要注意:子组件接收从父组件传递过来的内容,但是不可以修改从父组件传递过来的内容(修改会报错)
但如果我一定有修改那个子组件的需求,怎么办?
可以在data内创建一个数据,将从父组件传过来的值复制到这个data内,利用上面的例子,大致操作如下:

 props:['content'],
data:function() {
    return {
        number:this.count
    }
}

然后子组件后面操作就可以用number来操作,而不是操作父组件传来的count。
既然有了从父组件向子组件传递数据,那么也有从子组件向父组件传递数据,这个得看下一节

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 您将在本文当中了解到,往网页中添加数据,从传统的dom操作过渡到数据层操作,实现同一个目标,两种不同的方式....
    itclanCoder阅读 25,905评论 1 12
  • 主要还是自己看的,所有内容来自官方文档。 介绍 Vue.js 是什么 Vue (读音 /vjuː/,类似于 vie...
    Leonzai阅读 3,375评论 0 25
  • vue概述 在官方文档中,有一句话对Vue的定位说的很明确:Vue.js 的核心是一个允许采用简洁的模板语法来声明...
    li4065阅读 7,270评论 0 25
  • 组件(Component)是Vue.js最核心的功能,也是整个架构设计最精彩的地方,当然也是最难掌握的。...
    六个周阅读 5,652评论 0 32
  • 从去年上半年开始,一直到现在,各类垂直行业、平台类的o2o火的一塌糊涂,卖饭的、搞水果的、按摩的、修指甲的,都在往...
    乐水三千阅读 346评论 0 5