经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JSJS库框架 » JavaScript » 查看文章
Vue组件之间通信的三种方式
来源:cnblogs  作者:Kaiser_Lee  时间:2018/9/28 17:22:15  对本文有异议

最近在看梁颠编著的《Vue.js实战》一书,感觉颇有收获,特此记录一些比价实用的技巧。

组件是MVVM框架的核心设计思想,将各功能点组件化更利于我们在项目中复用,这类似于我们服务端面向对象三大特性之一的封装,将复杂的会被多次调用的代码封装成组件,在需要调用的地方注册使用即可。这样设计的前端代码方便移植,可以跨项目复用。

组件之间的关系分为父子组件兄弟组件和跨多级组件等等,在组件之间交互数据,进行通信主要通过三种方式来进行:

  1. 中央事件总线(非父子组件通信)
  2. 父链
  3. 子组件索引

下面让我们来好好说道说道这三种通信方式:

一.中央事件总线

  这个东西名字叫的很唬人,但实际却是很好理解的一种通信方式,话不多说,我们来上代码。

  

  1. <body>
  2. <div id="app">
  3. {{message}}
  4. <tempcomponent-a></tempcomponent-a>
  5. </div>
  6. <script>
  7. var middleware = new Vue();
  8. Vue.component('tempcomponent-a', {
  9. template: '<button @click="handleEvent">传递事件</button>',
  10. methods: {
  11. handleEvent: function () {
  12. middleware.$emit('on-message', '来自组件tempcomponent-a的内容');
  13. }
  14. }
  15. });
  16. var app = new Vue({
  17. el: '#app',
  18. data: {
  19. message: ''
  20. },
  21. mounted: function () {
  22. var _this = this;
  23. middleware.$on('on-message', function (msg) {
  24. _this.message = msg;
  25. })
  26. },
  27. });
  28. </script>
  29. </body>

在上面的代码中,空的Vue实例"middleware"就是我们的所谓的中央事件总线,我们可以看到,它负责在自组件"tempcomponent-a"中发出事件,在我们的主体Vue实例app中,通过监听"middleware"来获取子组件发出的内容。我的理解是中央事件总线就类似我们做交换数据的时候的临时变量一样,它在中间负责处理结果,然后返回消息给请求者,它的职责就是中介。这个空的vue实例也可以加入data,methods等选项,这些都是可以作为公用的。

二.父链$parent

父链这个词就很好理解啦,顾名思义即是组件的父对象,在组件内部可以直接通过$parent对父对象进行操作

  1. <body>
  2. <div id="app">
  3. {{message}}
  4. <tempcomponent-a></tempcomponent-a>
  5. </div>
  6. <script>
  7. Vue.component('tempcomponent-a', {
  8. template: '<button @click="handleEvent">通过父链直接修改数据</button>',
  9. methods: {
  10. handleEvent: function () {
  11. this.$parent.message = '来自组件tempcomponent-a的消息';
  12. }
  13. }
  14. });
  15. var app = new Vue({
  16. el: '#app',
  17. data: {
  18. message: ''
  19. }
  20. })
  21. </script>
  22. </body>

通过上面的代码,我们可以看到在自组件内,使用父链$parent直接对父对象对属性操作是非常简单的。

三.子组件索引ref&$refs

子组件这个也很好理解,是在父对象上对所拥有对子组件进行操作,一般来说父容器内对子组件会有多个,所以每个组件需要设置特殊属性ref来为自身指定一个唯一名称。

  1. <body>
  2. <div id="app">
  3. <button @click="handleRef">通过ref获取子组件实例</button>
  4. <tempcomponent-a ref="comA"></tempcomponent-a>
  5. </div>
  6. <script>
  7. Vue.component('tempcomponent-a', {
  8. template: '<div>子组件</div>',
  9. data: function () {
  10. return {
  11. message: '子组件内容'
  12. }
  13. }
  14. });
  15. var app = new Vue({
  16. el: '#app',
  17. methods: {
  18. handleRef: function () {
  19. var msg = this.$refs.comA.message;
  20. console.log(msg);
  21. }
  22. }
  23. })
  24. </script>
  25. </body>

从代码可以看出,当我们直接在组件上创建ref属性,在父对象中想对子组件进行操作,直接通过$refs.加上该组件唯一对ref属性即可访问。注意$refs是子组件渲染完成之后才填充对,而且不是响应式,应避免在计算属性和模版中使用$refs

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号