Vue父子组件通信(父级向子级传递数据子级向父级传递数据Vue父子组件存储到data数据的访问)
Posted 一乐乐
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue父子组件通信(父级向子级传递数据子级向父级传递数据Vue父子组件存储到data数据的访问)相关的知识,希望对你有一定的参考价值。
Vue父子组件通信(父级向子级传递数据、子级向父级传递数据、Vue父子组件存储到data数据的访问)
一、父级向子级传递数据【Prop】:
● Prop:子组件在自身标签上,使用自定义的属性来接收外界(也可以是父组件)的数据,然后将数据接收到prop中。【接收父组件的数据—动态Prop,需要v-bind绑定属性,数据可以从vue实例中获取】
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>html暂时不支持驼峰写法</title> </head> <body> <div id="app"> <!-- 子组件要或者外界(例如也可以是父组件)的数据,它是需要在自身标签上,使用props中自定义的属性来接收, 若是想接收的数据来自父组件【Vue实例】------通过绑定属性(数据可以从vue实例中获取) --> <!--静态的prop--> <cpn c-info="info"></cpn><br/> <!--动态prop--> <cpn :c-info="info"></cpn> </div> <template id="cpn"> <div> <h1>cpn的内容</h1> <ul> <li v-for="item in cInfo">item</li> </ul> </div> </template> </body> <script type="text/javascript" src="./js/vue.min.js"></script> <script> const cpn = template: `#cpn`, props: cInfo: type: Object, default() return , let app = new Vue( el: \'#app\', data: message:\'动态绑定属性v-bind\', abc: id: \'1\', name: \'父类的info中的name\', age: \'1\' , info: id: \'1\', name: \'父类的info中的name\', age: \'15\' , components: cpn ); </script> </body> </html>
二、子级向父级传递数据【emit】:
● 子组件通过$emit(‘自定义事件名’, 数据变量)向父组件发送消息,在子组件进行自定义的事件进行监听【监听调用的函数可以直接通过一个自定义的参数接收到数据变量】
<!-- 父组件 --> <div id="app"> <!-- 子组件上监听到自定义的事件的同时,也监听到发送的数据num,事件指向的函数,通过自定义一个参数value可以直接拿到数据num --> <cpn :c-info="info" @item-click="itemClick"></cpn> </div> <!-- 子组件的模板 --> <template id="cpn"> <div> <h1>子组件的模板</h1> <button v-for="item in cInfo" @click="btnClick(item)">item</button> </div> </template> </body> <script type="text/javascript" src="js/vue.min.js"></script> <script> const cpn = template: `#cpn`, data() return num: 99 , props: cInfo: type: Object, default() return , methods: btnClick(item) console.log(\'子组件接收到父组件传递的数据\' + item); //$emit的第一个参数是自定义的事件名称和发送数据num this.$emit(\'item-click\', this.num); let app = new Vue( el: \'#app\', data: info: id: \'1\', name: \'yile\', age: \'15\' , methods: itemClick(value) console.log(\'父组件监听到子组件发出的事件和接收到子组件的数据\' + value); , components: cpn ); </script>
三、Vue父子组件存储数据的访问:
(1)父组件访问子组件data中存储的数据:使用$children或 $refs (注意:this.$children得到的是一个数组,包含所有子组件对象。)
(2)$refs的使用:
■ $refs和ref指令通常是一起使用的
■ 首先,我们通过ref给某一个子组件绑定一个特定的ID
■ 其次,通过this.$refs.ID就可以访问到该组件了
以上是关于Vue父子组件通信(父级向子级传递数据子级向父级传递数据Vue父子组件存储到data数据的访问)的主要内容,如果未能解决你的问题,请参考以下文章