Vue中父子组件的值传递与方法传递
作者:WanGqD
这篇文章主要介绍了Vue中父子组件的值传递与方法传递,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
一.Vue中父组件向子组件传值
利用v-bind向子组件传值,子组件中利用props接受
<div id="app"> <father></father> </div> <template id="father"> <div> <!--注意点: 组件是可以使用自己的数据的--> <p>{{name}}</p> <p>{{age}}</p> <!--这里将父组件的name通过parentname传递给了子组件--> <son :parentname="name" :abc="age"></son> </div> </template> <template id="son"> <div> <!--这里通过parentname使用了父组件传递过来的数据--> <p>{{parentname}}</p> <p>{{abc}}</p> </div> </template> <script> // 父组件 Vue.component("father", { template: "#father", data: function(){ return { name: "wqd", age: 21 } }, // 子组件 components: { "son": { template: "#son", //这里通过parentname接收了父组件传递过来的数据 props: ["parentname", "abc"] } } }); // 这里就是MVVM中的View Model let vue = new Vue({ el: '#app', // 这里就是MVVM中的Model data: { }, }); </script>
二.Vue中父组件向子组件传递方法
父组件利用v-on传值,子组件this.$emit来接收
<div id="app"> <father></father> </div> <template id="father"> <div> <button @click="say">我是按钮</button> <!--这里通过parentsay将父组件的say方法传递给了子组件--> <son @parentsay="say"></son> </div> </template> <template id="son"> <div> <button @click="sonFn">我是按钮</button> </div> </template> <script> // 父组件 Vue.component("father", { template: "#father", methods: { say(){ console.log("helloworld") } }, // 子组件 components: { "son": { template: "#son", /* 注意点: 和传递数据不同, 如果传递的是方法, 那么在子组件中不需要接收,需要在子组件自定义的方法中通this.$emit("自定义接收的名称")的方法来触发父组件传递过来的方法 */ // props: ["parentsay"] methods: { sonFn(){ this.$emit("parentsay"); } } } } }); // 这里就是MVVM中的View Model let vue = new Vue({ el: '#app', // 这里就是MVVM中的Model data: { }, }); </script>
三.Vue中子组件向父组件传值
this.$emit中第一个参数为接收父组件传递的方法,第二个参数即为向父组件传递的值
<div id="app"> <father></father> </div> <template id="father"> <div> <button @click="say">我是按钮</button> <!--这里通过parentsay将父组件的say方法传递给了子组件--> <son @parentsay="say"></son> </div> </template> <template id="son"> <div> <button @click="sonFn">我是按钮</button> </div> </template> <script> // 父组件 Vue.component("father", { template: "#father", methods: { //data用来接受子组件传递的值 say(data){ console.log(data); } }, // 子组件 components: { "son": { template: "#son", methods: { sonFn(){ // 第一个参数: 需要调用的函数名称 // 后续的参数: 给调用的函数传递的参数 this.$emit("parentsay", "你好"); } } } } }); // 这里就是MVVM中的View Model let vue = new Vue({ el: '#app', // 这里就是MVVM中的Model data: { }, }); </script>
到此这篇关于Vue中父子组件的值传递与方法传递的文章就介绍到这了,更多相关Vue父子组件传递内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
- vue父子组件的互相传值和调用
- vue 使用 v-model 双向绑定父子组件的值遇见的问题及解决方案
- vue中父子组件的参数传递和应用示例
- Vue父子组件传值的一些坑
- 详解vue父子组件状态同步的最佳方式
- Vue 组件的挂载与父子组件的传值实例
- vue中组件通信详解(父子组件, 爷孙组件, 兄弟组件)
- vue中父子组件传值,解决钩子函数mounted只运行一次的操作
- 快速了解Vue父子组件传值以及父调子方法、子调父方法
- vue父子组件间引用之$parent、$children
- vue.js使用v-model实现父子组件间的双向通信示例
- vuejs中父子组件之间通信方法实例详解
- Vue组件通信中非父子组件传值知识点总结
- Vue 使用Props属性实现父子组件的动态传值详解
- vue父子组件的通信方法(实例详解)
- vue-父子组件和ref实例详解
- vue父子组件通信的高级用法示例
- Vue中的父子组件通讯以及使用sync同步父子组件数据