Vue组件通信实践记录(推荐)

发布时间 - 2026-01-11 02:48:16    点击率:

组件通信

几乎所有的mvvm框架中都要涉及组件通信的功能(吐槽一下knockout,毕竟是鼻祖就先不说它了)。而且目前的前端形式来看,组件化是一个项目的基础。所以选好一个合适的框架后,随着组件的不断增加,业务的复杂度提升,组件之间的通信变得尤为重要。

实践方法

由于更换新的框架,我们的项目由Avalon更新成Vue.但是为了兼容以前的业务代码,不能直接使用vue的标准实践方式,我还是拿过来后封装了一个vue的class,具体业务里面不影响使用,封装的过程之后写出来再聊吧,下面来总结一下最近用到的通信实践方法。

1.父组件是通过props传递数据给子组件

vmodel 中包含了两个子组件

<div class="w-base">
  <book-component v-bind:bookdata="book"></book-component>
</div>

<div class="base">
  <node-component v-bind:catalog="catalog" ></node-component>
</div>

在上面这段代码中我们可以看到,定义了两个子组件,并且使用指定v-bind指令传递了数据,子组件会接收到传递的数据。

Vue.component('book-component', {
 template: tpl,//可以传进来子组件的模板文件
 props: ['book'],
 data: function () {
  return { myBook: this.bookdata }
 }
})

建议接收到单向的props数据后,定义一个局部变量来初始化使用。

2.父组件与子组件之间通信的其他方式

vue中给实例提供了三个我们可用的API $children 和 $refs 以及 $parent 。

$children :当前实例的直接子组件。需要注意 $children 并不保证顺序,也不是响应式的。

$refs :包含了当前实例所有拥有 ref 注册的子组件的对象.

$parent : 当前实例的父实例。

所以说,如果在通信方面我们我组件想要调用子组件,能用的方法只有 $refs 了,因为 $children 是一个数组,并且不保证顺序,也没有相关的id去寻找我们需要的那个特定子组件。但是如果使用 $refs 去寻找特定子组件,那就必须要给那个子组件注册 ref 。

父组件的模版

<!-- vm.$refs.child will be the child comp instance -->
<child-component ref="child"></child-comp>

父组件

//找到子组件并且调用它的方法
var myChild = this.$refs.child;
mymyChild.func();

子组件

//找到父组件并且调用它的方法
var myParent = this.$parent;
mymyChild.func();

3.平行组件之间的两种通信方式

a.官方提供的事件bus

var bus = new Vue()
// 触发组件 A 中的事件
bus.$emit('id-selected', 1)
// 在组件 B 创建的钩子中监听事件
bus.$on('id-selected', function (id) {
 // ...
})

b.通过父组件去找兄弟组件

//找到父组件的$refs对象,然后找到组件的兄弟组件
 var $refs = this.$parent?this.$parent.$refs:{};
 var childComponent = $refs.child; //child为改组件的ref属性值

其实以上两种方法最好的实践方式是封装到项目的基类中,这样不用每次都去定义一个空Vue()实例,而是每个实例的基类中都有这个事件bus。同样可以封装找到其他兄弟组件的方法,但是该兄弟组件必须注册ref

下面这个方法是我在项目中封装的用于找到父组件,然后再去找到兄弟组件的方法。

//平行组件之间的通信
getComponentByRef: function(refId) {
  var $refs = this.$parent?this.$parent.$refs:{};
  for (var $id in $refs) {
    if ($id == refId) {
      return $refs[$id];
    }
  }
  return null;
}

使用

//在组件中直接使用
this.getComponentByRef("booknode").updateNode(this.node);

4.组件间复杂数据通信Vuex

一说到vuex,很多刚开始接触vue的人会主动避免去使用它,其实它并没有想象中的那么复杂。最好的开始是引入vuex后,走一遍给出的小示例。但是如果你的项目并不复杂的话,可以不考虑状态管理,那么什么时候需要使用状态管理呢?

我们来看这样一个布局

如果component1中的某个数据变更,那么com2,com3也要跟着更新,此时com3中又细分为了三个小组件。

问题:

  1. 多个试图依赖同一个状态
  2. 多层嵌套的组件,数据变更和代码维护困难

那这样的情况时,我们可以考虑使用状态管理。下一篇文章将详细讲解关于vuex的实践和理解。

写在最后的总结

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Vue  # 组件通信  # Vue组件通信实践  # Vuejs第十篇之vuejs父子组件通信  # 深入探讨Vue.js组件和组件通信  # vue2.0父子组件及非父子组件之间的通信方法  # 详解vue2.0组件通信各种情况总结与实例分析  # Vue2.x中的父子组件相互通信的实现方法  # Vue 父子组件、组件间通信  # vue组件间通信解析  # 详解Vue组件之间的数据通信实例  # 详解vue组件通信的三种方式  # 是一个  # 最好的  # 两种  # 类中  # 都有  # 我在  # 包含了  # 都要  # 那就  # 多个  # 也要  # 什么时候  # 说到  # 这段  # 一遍  # 我们可以  # 去找  # 下一  # 数据通信  # 这样一个 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: iOS发送验证码倒计时应用  如何在阿里云虚拟主机上快速搭建个人网站?  jquery插件bootstrapValidator表单验证详解  Laravel如何使用Eloquent进行子查询  如何快速查询网址的建站时间与历史轨迹?  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  如何在云主机上快速搭建网站?  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  成都网站制作公司哪家好,四川省职工服务网是做什么用?  php打包exe后无法访问网络共享_共享权限设置方法【教程】  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)  Android 常见的图片加载框架详细介绍  如何在阿里云虚拟服务器快速搭建网站?  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel如何使用Gate和Policy进行授权?(权限控制)  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  深圳网站制作公司好吗,在深圳找工作哪个网站最好啊?  Edge浏览器提示“由你的组织管理”怎么解决_去除浏览器托管提示【修复】  香港网站服务器数量如何影响SEO优化效果?  手机怎么制作网站教程步骤,手机怎么做自己的网页链接?  如何为不同团队 ID 动态生成多个独立按钮  Laravel中DTO是什么概念_在Laravel项目中使用数据传输对象(DTO)  Laravel DB事务怎么使用_Laravel数据库事务回滚操作  如何用虚拟主机快速搭建网站?详细步骤解析  Laravel怎么实现API接口鉴权_Laravel Sanctum令牌生成与请求验证【教程】  Laravel Vite是做什么的_Laravel前端资源打包工具Vite配置与使用  Laravel如何使用Sanctum进行API认证?(SPA实战)  iOS中将个别页面强制横屏其他页面竖屏  Laravel如何创建自定义Facades?(详细步骤)  Laravel如何发送系统通知_Laravel Notifications实现多渠道消息通知  想要更高端的建设网站,这些原则一定要坚持!  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  Laravel如何安装Breeze扩展包_Laravel用户注册登录功能快速实现【流程】  如何快速上传建站程序避免常见错误?  Win11任务栏卡死怎么办 Windows11任务栏无反应解决方法【教程】  JavaScript常见的五种数组去重的方式  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  微信小程序 HTTPS报错整理常见问题及解决方案  广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?  java获取注册ip实例  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  如何快速配置高效服务器建站软件?  车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  Laravel如何实现数据库事务?(DB Facade示例)  如何挑选优质建站一级代理提升网站排名?