Vue和React组件之间的传值方式详解


Posted in Javascript onJanuary 31, 2019

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

组件间的传值方式

组件的传值场景无外乎以下几种:

  • 父子之间
  • 兄弟之间
  • 多层级之间(孙子祖父或者更多)
  • 任意组件之间

父子之间

Vue

Vue是基于单项数据流设计的框架,但是提供了一些的语法,指令去实现一些操作

  • 父->子:通过props进行传递数据给子组件
  • 子->父:通过emit向父组件传值

同时,还有一些其他进行父子组件通信的方式,通过$parent和$children获取组件的父或者子组件的实例,之后通过实例对象去修改组件的属性。在表单控件中,使用v-model实现了双向数据绑定,其实这里v-model是一个语法糖,内部实现还是监听了表单控件的change事件,然后将数据传递给组件修改数据,从而实现了双向数据绑定。

React

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

兄弟之间

Vue

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

React

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

多层级组件

Vue

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

// 父级组件提供 'foo'
var Provider = {
 provide: {
  foo: 'bar'
 },
 // ...
}

// 子组件注入 'foo'
var Child = {
 inject: ['foo'],
 created () {
  console.log(this.foo) // => "bar"
 }
 // ...
}

React

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

// Theme context, default to light theme
const ThemeContext = React.createContext('light');

class App extends React.Component {
 render() {
  const {signedInUser, theme} = this.props;

  // App component that provides initial context values
  return (
   <ThemeContext.Provider value={theme}>
    <Layout />
   </ThemeContext.Provider>
  );
 }
}

function Layout() {
 return (
  <div>
   <Sidebar />
   <Content />
  </div>
 );
}

// A component may consume multiple contexts
function Content() {
 return (
  <ThemeContext.Consumer>
   {theme => (
     <ProfilePage theme={theme} />
   )}
  </ThemeContext.Consumer>
 );
}

任意组件之间

Vue

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

React

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

总结

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

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

Javascript 相关文章推荐
Jquery插件写法笔记整理
Sep 06 Javascript
JS Replace()的高级使用方法介绍
Jun 29 Javascript
简单谈谈javascript Date类型
Sep 06 Javascript
基于zepto的移动端轻量级日期插件--date_picker
Mar 04 Javascript
AngularJS基础 ng-list 指令详解及示例代码
Aug 02 Javascript
jQuery EasyUI中的日期控件DateBox修改方法
Nov 09 Javascript
vue利用better-scroll实现轮播图与页面滚动详解
Oct 20 Javascript
浅析JavaScript中的特殊数据类型
Dec 15 Javascript
Angular 项目实现国际化的方法
Jan 08 Javascript
vue使用自定义icon图标的方法
May 14 Javascript
详解javascript replace高级用法
Feb 17 Javascript
Javascript读取上传文件内容/类型/字节数
Apr 30 Javascript
使用Angular Cli如何创建Angular私有库详解
Jan 30 #Javascript
async/await优雅的错误处理方法总结
Jan 30 #Javascript
新年快乐! javascript实现超级炫酷的3D烟花特效
Jan 30 #Javascript
JavaScript之解构赋值的理解
Jan 30 #Javascript
JS实现点击按钮随机生成可拖动的不同颜色块示例
Jan 30 #Javascript
JS实现的新闻列表自动滚动效果示例
Jan 30 #Javascript
谈谈为什么你的 JavaScript 代码如此冗长
Jan 30 #Javascript
You might like
浅谈php的TS和NTS的区别
2019/03/13 PHP
PHP ob缓存以及ob函数原理实例解析
2020/11/13 PHP
如何让浏览器支持jquery ajax load 前进、后退功能
2014/06/12 Javascript
NodeJs基本语法和类型
2015/02/13 NodeJs
JS跨域解决方案之使用CORS实现跨域
2016/04/14 Javascript
JS实现将Asp.Net的DateTime Json类型转换为标准时间的方法
2016/08/02 Javascript
jQuery实现的tab标签切换效果示例
2016/09/05 Javascript
让浏览器崩溃的12行JS代码(DoS攻击分析及防御)
2016/10/10 Javascript
ionic2打包android时gradle无法下载的解决方法
2017/04/05 Javascript
vue.js的computed,filter,get,set的用法及区别详解
2018/03/08 Javascript
Angular ui-roter 和AngularJS 通过 ocLazyLoad 实现动态(懒)加载模块和依赖
2018/11/25 Javascript
layui表格 列自动适应大小失效的解决方法
2019/09/06 Javascript
layui使用templet格式化表格数据的方法
2019/09/16 Javascript
解决Python中由于logging模块误用导致的内存泄露
2015/04/23 Python
python动态网页批量爬取
2016/02/14 Python
浅谈python装饰器探究与参数的领取
2017/12/01 Python
python3+mysql查询数据并通过邮件群发excel附件
2018/02/24 Python
在Python中,不用while和for循环遍历列表的实例
2019/02/20 Python
python利用wx实现界面按钮和按钮监听和字体改变的方法
2019/07/17 Python
Python3.7黑帽编程之病毒篇(基础篇)
2020/02/04 Python
如何配置关联Python 解释器 Anaconda的教程(图解)
2020/04/30 Python
Pycharm同步远程服务器调试的方法步骤
2020/11/04 Python
微信小程序实现可实时改变转速的css3旋转动画实例代码
2018/09/11 HTML / CSS
KIKO MILANO俄罗斯官网:意大利领先的化妆品和护肤品品牌
2021/01/09 全球购物
怎样声明接口
2014/09/19 面试题
好的自荐信的要求
2013/10/30 职场文书
《与象共舞》教学反思
2014/02/24 职场文书
《美丽的黄昏》教学反思
2014/02/28 职场文书
现金出纳岗位职责
2014/03/15 职场文书
工地宣传标语
2014/06/18 职场文书
我为党旗添光彩演讲稿
2014/09/13 职场文书
音乐教育专业自荐信
2014/09/18 职场文书
2015员工年度考核评语
2015/03/25 职场文书
青年干部培训班学习心得体会
2016/01/06 职场文书
《认识钟表》教学反思
2016/02/16 职场文书
python 自动化偷懒的四个实用操作
2021/04/11 Python