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

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

作者: 李浩然_6fd1 | 来源:发表于2019-02-13 15:35 被阅读0次

每一个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。
既然有了从父组件向子组件传递数据,那么也有从子组件向父组件传递数据,这个得看下一节

相关文章

  • ReactNative组件间的通信

    父组件向子组件通信 父组件向子组件传值 父组件向子组件传递方法 子组件向父组件通信 子组件向父组件传值 子组件向父...

  • Vue.js父子组件和非父子组件间的传值通信

    [toc] 父子组件的传值通信 父组件向子组件传值 父组件: 子组件: 子组件向父组件传值 Note 子组件不能直...

  • React组件通信

    1.父组件与子组件通信父组件传值到子组件props。2.子组件与父组件通信父组件向子组件传一个函数,子组件将自己的...

  • Vue 组件传值

    一、组件间通信传值的各种方式与场景 1、父组件向子组件(跨级)传值 1.1 父组件通过props给子组件传值 1....

  • Vue组件间通信

    Vue组件间通信 父子组间通信 通过props向子组件传值,通过事件向父级组件发送消息 通过props向子组件传值...

  • react组件通信

    父->子通信父组件向子组件传值 使用组件属性的形式父组件给子组件传值。比如:我们在...

  • Vue的组件通信

    1、父组件向子组件 props 用props进行组件间的通信可以轻而易举的实现父往子传值 2、子组件向父组件 $e...

  • 19.ReactNative组件间的通信

    父组件向子组件通信: 父组件向子组件传值 通过props传递 在父组件中name='我是父组件向子组件传递的参数'...

  • ReactNative组件间的通信

    父组件向子组件通信 父组件向子组件传值 通过props传递 在父组件中name='我是父组件向子组件传递的参数' ...

  • react-父子组件间通信

    React-父子组件间通信 父组件传 值 给子组件, 传 方法 给子组件 子组件接收 值 ,触发父组件的 方法

网友评论

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

      本文链接:https://www.haomeiwen.com/subject/rvcssqtx.html