vue前端开发层次嵌套组件的通信详解
程序员文章站
2022-07-06 08:14:30
目录前言vue父子组件之间通过props很容易的将父组件的值传递给子组件,如果一个组件嵌套很多层,每一层之间度需要同props进行传值,很麻烦,且不易维护示例【示例】a组件中使用了b组件,b组件中使用...
前言
vue父子组件之间通过props很容易的将父组件的值传递给子组件,如果一个组件嵌套很多层,每一层之间度需要同props进行传值,很麻烦,且不易维护
示例
【示例】a组件中使用了b组件,b组件中使用了c组件,c组件需要使用a组件的数据text及使用a组件的方法getmethod。a组件代码如下:
<template> <div> <p>这是a组件</p> <v-comb></v-comb> </div> </template> <script> import comb from '@/view/comb.vue' export default { name: 'coma', components: { 'v-comb': comb }, data() { return { msg: '我是组件a中数据' } }, provide: function() { //注入给子组件属性和方法 return { text: this.msg, getmethod: function() { console.log('执行根组件中的getmethod方法') } } } } </script>
使用关键字provide,将数据和方法暴露给子组件
b组件是a组件子组件,是c组件的父组件,代码如下
<template> <div> <div> <p>这是b组件</p> <v-comc></v-comc> </div> </div> </template> <script> import comc from '@/view/comc.vue' export default { name: 'comb', components: { 'v-comc': comc } } </script>
c组件是a组件的孙子组件,c组件需要使用a组件的数据和方法,代码如下:
<template> <div style="border:1px solid orange;color:orange;"> <div> <p>这是c组件</p> <div>{{text}}</div> <button @click="getmethod">调用父组件方法</button> </div> </div> </template> <script> export default { name: 'comc', inject: ['text', 'getmethod'] //text和getmethod是provide提供的名字 } </script>
这里使用inject关键字,接收a组件暴露的信息,这里特别注意, inject: []中接收名字必须与provide提供的名字完全一致。
运行,界面如下图所示
小结
多层次组件嵌套通信,vue通过provide & inject两个关键字完成父组件向子孙组件直接传值,使用起来非常方便。存在问题子组件与父组件存在一种强耦合关系,不再万不得已时不建议使用。
以上就是vue前端开发层次嵌套组件的通信详解的详细内容,更多关于vue层次嵌套组件通信的资料请关注其它相关文章!
上一篇: 课堂上的搞笑造句、摸底考试和翻译
下一篇: 已经一年不联系为什么还想念