美文网首页
Vue和React组件之间的传值方式对比总结

Vue和React组件之间的传值方式对比总结

作者: agamgn | 来源:发表于2020-01-22 11:46 被阅读0次

前言

    在开发单页面的时候,组件之间的传值一直是很重要的一部分,其中两个Vue和React框架,组件间传值方式有哪些呢?

组件间的传值方式

组件之间的传值方式主要有以下四种:

  • 1.父子之间
  • 2.兄弟之间
  • 3.多层级之间(孙子祖父等)
  • 4.任意组件之间

父子之间

Vue

父->子:通过props进行传递数据给子组件
demo1-code.png demo1.png
子->父:通过emit向父组件传值
demo2-code.png demo2.png

同时,还有一些其他进行父子组件通信的方式,通过$parent和$children获取组件的父或者子组件的实例,之后通过实例对象去修改组件的属性。

React

父->子:通过props将数据传递给子组件
demo3-code.png demo3.png
子->父:通过父组件向子组件传递函数,然后子组件中调用这些函数,利用回调函数实现数据传递
demo4-code.png demo4.png

兄弟之间

Vue

在Vue中,可以通过查找父组件下的子组件实例,然后进行组件进行通信。如this.parent.children,在$children中,可以通过组件的name找到要通信的组件,进而进行通信。

React

在React中,需要现将数据传递给父组件,然后父组件再传递给兄弟组件。

多层级之间

Vue

在多层级的组件中,当然可以通过不断的获取$parent找到需要传递的祖先级组件,然后进行通信,但是这样繁琐易错,并不推荐。Vue在2.2.0 新增提供了provide/inject的方式进行传递数据。即在祖先组件提供数据,在需要使用的组件中,注入数据,这样就可以在子组件中使用数据了。
provide-inject

React

在React中,提供了一个和Vue类似的处理多层级组件通信的方式——context,这里会提供一个生产者和一个消费者,会在父组件中生产数据,在子组件中消费数据。从使用上来说,只需要将子组件包裹在生产者的Provider中,在需要用到数据的子组件中,通过Consumer包裹,就可以拿到生产者的数据。
context

任意组件之间

Vue

对于任意组件,简单的可以使用EventBus,对于更为复杂的建议使用Vuex。

React

简单的使用EventBus,复杂的使用Redux

总结

    当然,组件间的传值是灵活的,可以有多种途径,父子组件同样可以使用EventBus,Vuex或者Redux,只是遵循框架开发者的建议,以及适应开发的比较好的实践而已。

本章React代码
本章Vue代码

相关文章

  • Vue和React组件之间的传值方式对比总结

    前言 在开发单页面的时候,组件之间的传值一直是很重要的一部分,其中两个Vue和React框架,组件间传值方式有哪些...

  • Vue和React组件通信的总结

    在现代的三大框架中,其中两个Vue和React框架,组件间传值方式有哪些? 组件间的传值方式 组件的传值场景无外乎...

  • react子组件向父组件传值

    相关资料:react 父组件怎么获取子组件的这个值React组件间信息传递方式react同级组件之间传值 • 父...

  • Uniapp兄弟组件传值

    兄弟组件a.vue和b.vue之间的传值方式 a.vue b.vue

  • vue 中几种传值方法

    前言 vue项目中,组件跟组件之间数据的传递是很普遍的行为,在这里总结几种常见的vue组件跟组件之间传值方式,其中...

  • vue组件间传值问题总结

    vue项目中,组件间传值的问题总结: 父传子 父组件 子组件 上面父组件和子组件之间的传值是模拟接口请求数据,然后...

  • vue 6种通信总结①

    常用vue通信大概有这几种方式进行: 组件间的父子之间的传值 组件间的子父之间的传值 非组件间的组件间的传值(简称...

  • vue3 - 父子组件之间的传值 2022-03-01

    近期学习 vue3 的父子组件之间的传值,发现跟 vue2.x的父子组件之间的传值 并没有太大的区别,我这边总结一...

  • Vue学习笔记之组件传值

    前言 在Vue开发过程中总会遇到组件之间传值的问题,这里总结一下现在学习到的组件之间的传值方法。 组件传值个人感觉...

  • 与Vue.js的第八天

    今天学习了Vue组件中的非父子之间的传值和生命周期Vue组件之间的传值分三种1.父传子之间传值用属性:props2...

网友评论

      本文标题:Vue和React组件之间的传值方式对比总结

      本文链接:https://www.haomeiwen.com/subject/pgrgactx.html