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


Posted in Javascript onAugust 15, 2017

组件通信

几乎所有的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后,走一遍给出的小示例。但是如果你的项目并不复杂的话,可以不考虑状态管理,那么什么时候需要使用状态管理呢?

我们来看这样一个布局

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

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

问题:

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

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

写在最后的总结

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

Javascript 相关文章推荐
[原创]图片分页查看
Aug 28 Javascript
DOM2非标准但却支持很好的几个属性小结
Jan 21 Javascript
IE6-IE9不支持table.innerHTML的解决方法分享
Sep 14 Javascript
DIV始终居中的js代码
Feb 17 Javascript
jQuery实现不断闪烁文字的方法
May 15 Javascript
JQuery实现超链接鼠标提示效果的方法
Jun 10 Javascript
谈谈JavaScript自定义回调函数
Oct 18 Javascript
jquery+ajax+text文本框实现智能提示完整实例
Jul 09 Javascript
JavaScript无缝滚动效果的实例代码
Mar 27 Javascript
详解Webpack+Babel+React开发环境的搭建的方法步骤
Jan 09 Javascript
使用webpack编译es6代码的方法步骤
Apr 28 Javascript
es6数组的flat(),flatMap()函数用法实例分析
Apr 18 Javascript
js移动端事件基础及常用事件库详解
Aug 15 #Javascript
js实现移动端轮播图效果
Dec 09 #Javascript
JavaScript递归算法生成树形菜单
Aug 15 #Javascript
JavaScript中附件预览功能实现详解(推荐)
Aug 15 #Javascript
input输入框内容实时监测(附代码)
Aug 15 #Javascript
vue的基本用法与常见指令
Aug 15 #Javascript
vue如何集成raphael.js中国地图的方法示例
Aug 15 #Javascript
You might like
十大催泪虐心动漫,你能坚持看到第几部?
2020/03/04 日漫
PHP个人网站架设连环讲(四)
2006/10/09 PHP
IIS安装Apache伪静态插件的具体操作图文
2013/07/01 PHP
PHP Hash算法:Times33算法代码实例
2015/05/13 PHP
php+html5基于websocket实现聊天室的方法
2015/07/17 PHP
php+redis在实际项目中HTTP 500: Internal Server Error故障排除
2017/02/05 PHP
php实现的统计字数函数定义与使用示例
2017/07/26 PHP
PHP使用HTML5 FileApi实现Ajax上传文件功能示例
2019/07/01 PHP
给moz-firefox下添加IE方法和属性
2007/04/10 Javascript
Js,alert出现乱码问题的解决方法
2013/06/19 Javascript
jQuery实现div浮动层跟随页面滚动效果
2014/02/11 Javascript
Jquery给基本控件的取值、赋值示例
2014/05/23 Javascript
require.js深入了解 require.js特性介绍
2014/09/04 Javascript
AngularJS中的过滤器filter用法完全解析
2016/04/22 Javascript
详解jQuery中的事件
2016/12/14 Javascript
jQuery操作css样式
2017/05/15 jQuery
谈谈vue中mixin的一点理解
2017/12/12 Javascript
Express进阶之log4js实用入门指南
2018/02/10 Javascript
JavaScript使用递归和循环实现阶乘的实例代码
2018/08/28 Javascript
python的numpy模块安装不成功简单解决方法总结
2017/12/23 Python
Flask框架Flask-Login用法分析
2018/07/23 Python
详解Django配置优化方法
2019/11/18 Python
pyftplib中文乱码问题解决方案
2020/01/11 Python
Python根据URL地址下载文件并保存至对应目录的实现
2020/11/15 Python
乐高瑞士官方商店:LEGO CH
2020/08/16 全球购物
璀璨的珍珠、密钉和个性化珠宝:Lily & Roo
2021/01/21 全球购物
linux面试题参考答案(4)
2014/09/21 面试题
理工大学毕业生自荐信范文
2014/02/22 职场文书
有趣的广告词
2014/03/18 职场文书
我的梦想演讲稿500字
2014/08/21 职场文书
八一建军节演讲稿
2014/09/10 职场文书
高一课前三分钟演讲稿
2014/09/13 职场文书
2014年教师工作总结
2014/11/10 职场文书
五一劳动节慰问信
2015/02/14 职场文书
高中运动会广播稿
2015/08/19 职场文书
如何正确理解python装饰器
2021/06/15 Python