vue父子组件的通信

一、父组件向子组件传递数据

1、首先形成父子组件关系

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="app">

    </div>

    <template id="cpn">
        <div>
            <h2>{{cmovies}}</h2>
            <p>{{cmessage}}</p>
        </div>
    </template>
    <script>
        const cpn = {
            template: `#cpn`,
            data() {
                return {}
            },
            methods: {}
        }
        let vm = new Vue({
            el: ‘#app‘,
            data: () => ({
                message: ‘父组件的数据‘,
                movies: [‘战狼1‘, ‘流浪地球‘, ‘攀登者‘]
            }),
            components: {
                cpn
            }
        })
    </script>
</body>

</html>

2、在子组件中定义一个props,定义两个变量 (messages) (moviess)

props: [‘messages‘, ‘moviess‘]

3、使用子组件时,用V-bind绑定两个变量(messages) (moviess),并且把父组件中的数据(message)(movies)传给这两个变量。

<cpn :messages="message" :moviess="movies"></cpn>
<!-- 不支持驼峰命名法 大写字母之间用 - 隔开 -->

****完整代码*****

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>

<body>
    <div id="app">
        <cpn :messages="message" :moviess="movies"></cpn>
        <!-- 不支持驼峰命名法 大写字母之间用 - 隔开 -->
    </div>
    <!-- 父传子 -->
    <!--
        1、建立父子关系
        2、在子组件中定义一个props,定义两个变量 (messages) (moviess)
        3、使用子组件时,用V-bind绑定两个变量,并且把父组件中的数据(message)(movies)传给这两个变量。

     -->
    <template id="cpn">
        <div>
            <h2>{{messages}}</h2>
            <ul>
                <li v-for="item in moviess">
                    {{item}}
                </li>
            </ul>
        </div>
    </template>
    <script>
        const cpn = {
            template: `#cpn`,
            // props: [‘messages‘, ‘moviess‘],

            props: {
                // 1、类型限制
                // messages:Array,
                // moviess:String,

                // 提供一些默认值
                messages: {
                    type: String,
                    default: ‘aaaa‘,
                    required: true
                },
                // 当使用组件的时候,没有绑定props中定义的变量,就会显示定义的默认值
                moviess: {
                    // 类型是对象或数组,默认值必需是一个函数。
                    type: Array,
                    // default: []
                    default() {
                        return []
                    }
                }
            },
            data() {
                return {}
            },
            methods: {}

        }
        let vm = new Vue({
            el: ‘#app‘,
            data: () => ({
                message: ‘父组件的数据‘,
                movies: [‘战狼1‘, ‘流浪地球‘, ‘攀登者‘],

            }),
            components: {
                cpn
            }
        })
    </script>
</body>

</html>

** props中补充写法

props: {
                // 1、类型限制
                // messages:Array,
                // moviess:String,

                // 提供一些默认值
                messages: {
                    type: String,
                    default: ‘aaaa‘,
                    required: true
                },
                // 当使用组件的时候,没有绑定props中定义的变量,就会显示定义的默认值
                moviess: {
                    // 类型是对象或数组,默认值必需是一个函数。
                    type: Array,
                    // default: []
                    default() {
                        return []
                    }
                }
            }

二、子组件向父组件传数据

1、构成父子组件关系

2、在子组件中自定义一个事件      作用:发射一个事件给父组件

<button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>
            methods: {
                btnclick: function (item) {
                    // 发射事件:自定义事件
                    this.$emit(‘itemclick‘, item)
                }
            }

3、在父组件的模板中使用子组件中定义的事件 @itemclick="cpnclick"   并且在父组件创建一个新的事件 cpnclick

<cpn @itemclick="cpnclick"></cpn>
            methods: {
                cpnclick: function (item) {
                    console.log(‘cpnclick‘, item)
                }
            }

***完整代码***

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="../js/vue.js"></script>
</head>
<!-- 父组件模板 -->
<div id="app">
    <cpn @itemclick="cpnclick"></cpn>
</div>
<!--
    1、构成父子组件关系
    2、在子组件定义一个事件,作用是  发射一个事件给父组件。this.$emit(‘itemclick‘)
    3、在父组件的模板中使用子组件中定义的事件 @itemclick="cpnclick" ,并且在父组件创建一个新的事件 cpnclick ,
    这里面可以写传给父组件数据的逻辑以及限制
 -->

<body>
    <!-- 子组件模板 -->
    <template id="cpn">
        <div>
            <button v-for="item in categories" @click="btnclick(item)">{{item.name}}</button>
        </div>
    </template>
    <script>
        // 子组件
        const cpn = {
            template: `#cpn`,
            data() {
                return {
                    categories: [
                        { id: ‘aa‘, name: ‘热门推荐‘ },
                        { id: ‘bb‘, name: ‘手机数码‘ },
                        { id: ‘cc‘, name: ‘智能家居‘ },
                        { id: ‘dd‘, name: ‘美容美发‘ }
                    ]
                }
            },
            methods: {
                btnclick: function (item) {
                    // 发射事件:自定义事件
                    this.$emit(‘itemclick‘, item)
                }
            }
        }
        // 父组件
        let vm = new Vue({
            el: ‘#app‘,
            data: () => ({}),
            components: {
                cpn
            },
            methods: {
                cpnclick: function (item) {
                    console.log(‘cpnclick‘, item)
                }
            }
        })
    </script>
</body>

</html>

原文地址:https://www.cnblogs.com/DreamchaserHe/p/11766170.html

时间: 2024-07-31 03:17:32

vue父子组件的通信的相关文章

vue.js学习笔记(4)— 父子组件之间通信的第一种方式 props 和 $emit

我们知道,vue组件中,父组件把数组传递给子组件的话,通常是使用props传递,而vue规定,prop是只能单向下行传递的,那么子组件要怎么才能实现数据的向上传递呢,这里引述一个概念:"父子组件的关系:prop向下传递,事件向上传递",上一篇文章当中,关于数据向上传递用到的事件方法 $emit() 也进行了详细的说明,不懂的童鞋可以翻回去看一下.下面就是今天要说的父子组件相互通信的问题,点击效果依次如下: 代码如下: <!DOCTYPE html> <html>

【转】vue父子组件之间的通信

vue父子组件之间的通信 在vue组件通信中其中最常见通信方式就是父子组件之中的通性,而父子组件的设定方式在不同情况下又各有不同.最常见的就是父组件为控制组件子组件为视图组件.父组件传递数据给子组件使用,遇到业务逻辑操作时子组件触发父组件的自定义事件.无论哪种组织方式父子组件的通信方式都是大同小异. 父组件到子组件通讯 父组件到子组件的通讯主要为:子组件接受使用父组件的数据,这里的数据包括属性和方法(String,Number,Boolean,Object, Array ,Function).v

Vue父子组件传值

 Vue父子组件传值:有四种方式:props,ref,emit 和模板传递通信slot 通过props来传值: 静态传值就是直接通过props来传递 动态传值是通过v-bind来绑定一个要传递值的key,然后后面跟要传递的内容,不过这个内容是可以改变的 比如: <input v-model="parentMsg"> <child v-bind:message="parentMsg"></child> 传递的值会跟着input里面输

vue父子组件之间传值

vue父子组件进行传值 vue中的父子组件,什么是父组件什么是子组件呢?就跟html标签一样,谁包裹着谁谁就是父组件,被包裹的元素就是子组件. 父组件向子组件传值 下面用的script引入的方式,那种vue-cli搭建的同理 父组件通过 v-bind:属性名(自定义的) = "要传递的数据" 子组件通过 props:["属性名"]  这个属性名就是父组件传递过来的数据信息 <div id="app"> <mod :abc=&qu

一个故事讲懂vue父子组件传值

作者:李佳明同学链接:https://www.jianshu.com/p/2272b6ca0f0c 一个故事讲懂vue父子组件传值 讲故事前先讲代码 父组件向子组件传值 父组件数据传递给子组件可以通过props属性来实现父组件: <template>  <div id="app">    <child-component v-bind:dataOfChild="dataOfParent"></child-component&

vue父子组件的传值总结

久违的博客园我又回来了.此篇文章写得是vue父子组件的传值,虽然网上已经有很多了.写此文章的目的就是记录下个人学习的一部分.接下来我们就进入主题吧! 在开发vue项目中,父子组件的传值是避免不掉的. 情况一:父组件给子组件传值方法,使用props 父页面:parent.vue 1 <template> 2 <div class="sidebar_contianer"> 3 <sidebar-item :routerData="transmitDa

vue非父子组件间通信

有时候非父子关系的组件也需要通信.在简单的场景下,使用一个空的Vue实例作为中央事件总线: 有时候非父子关系的组件也需要通信.在简单的场景下,使用一个空的 Vue 实例作为中央事件总线: var bus = new Vue() // 触发组件 A 中的事件 bus.$emit('id-selected', 1) // 在组件 B 创建的钩子中监听事件 bus.$on('id-selected', function (id) { // ... }) 在更多复杂的情况下,你应该考虑使用专门的 状态管

Vue父子组件通信实践

组件(Component)是Vue.js的核心部分,组件的作用域是孤立的,所以不能在子组件模板内直接引用父组件的数据,但是组件之间的通信是必不可少的.组件A在其模板中使用了组件B,A组件要向B组件传递数据,B组件要将其内部发生的事情告知A组件,那么A.B组件怎么进行通信呢? Vue.js父子组件的关系可以总结为props down,events up,父组件通过props向下传递数据给子组件,子组件通过events给父组件发送消息,它们的工作方式如下图所示: 父组件 - 子组件:父组件传值给子组

Vue父子组件及非父子组件如何通信

1.父组件传递数据给子组件 父组件数据如何传递给子组件呢?可以通过props属性来实现 父组件: 子组件通过props来接收数据: 方式1: 方式2 : 方式3: 这样呢,就实现了父组件向子组件传递数据. 2.子组件与父组件通信 那么,如果子组件想要改变数据呢?这在vue中是不允许的,因为vue只允许单向数据传递,这时候我们可以通过触发事件来通知父组件改变数据,从而达到改变子组件数据的目的. 父组件: 3.非父子组件通信 如果2个组件不是父子组件那么如何通信呢?这时可以通过eventHub来实现