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 相关文章推荐
JavaScript 组件之旅(二)编码实现和算法
Oct 28 Javascript
带左右箭头图片轮播的JS代码
Dec 18 Javascript
js重写alert控件(适合学习js的新手朋友)
Aug 24 Javascript
JQuery核心函数是什么及使用方法介绍
May 03 Javascript
ES6中的箭头函数实例详解
Apr 06 Javascript
vue中使用localstorage来存储页面信息
Nov 04 Javascript
electron-vue开发环境内存泄漏问题汇总
Oct 10 Javascript
微信小程序实现音乐播放器
Nov 20 Javascript
小程序使用分包的示例代码
Mar 23 Javascript
jquery更改元素属性attr()方法操作示例
May 22 jQuery
html+vue.js 实现漂亮分页功能可兼容IE
Nov 07 Javascript
解决vue elementUI 使用el-select 时 change事件的触发问题
Nov 17 Vue.js
使用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
微信API接口大全
2015/04/15 PHP
CodeIgniter记录错误日志的方法全面总结
2016/05/17 PHP
php实现用户注册密码的crypt加密
2017/06/08 PHP
PHP7基于curl实现的上传图片功能
2018/05/11 PHP
PHP封装XML和JSON格式数据接口操作示例
2019/03/06 PHP
javascript 写类方式之四
2009/07/05 Javascript
javascript最常用与实用的创建类的代码
2010/08/12 Javascript
JavaScript实现x秒后自动跳转到一个页面
2013/01/03 Javascript
BootStrap3学习笔记(一)之网格系统
2016/05/20 Javascript
第一次接触神奇的Bootstrap基础排版
2016/07/26 Javascript
javascript淘宝主图放大镜功能
2016/10/20 Javascript
又一款MVVM组件 构建自己的Vue组件(2)
2017/03/13 Javascript
vue-cli之router基本使用方法详解
2017/10/17 Javascript
javascript浏览器用户代理检测脚本实现方法
2017/10/27 Javascript
原生JS实现ajax与ajax的跨域请求实例
2017/12/01 Javascript
详解vue+vuex+koa2开发环境搭建及示例开发
2018/01/22 Javascript
使用pm2部署node生产环境的方法步骤
2019/03/09 Javascript
基于Express框架使用POST传递Form数据
2019/08/10 Javascript
vue+vant实现商品列表批量倒计时功能
2020/01/13 Javascript
vue实现图片懒加载的方法分析
2020/02/05 Javascript
解决vue打包 npm run build-test突然不动了的问题
2020/11/13 Javascript
[01:59]深扒TI7聊天轮盘语音出处 1
2017/05/11 DOTA
运用TensorFlow进行简单实现线性回归、梯度下降示例
2018/03/05 Python
Python中常用的内置方法
2019/01/28 Python
Python给图像添加噪声具体操作
2019/03/03 Python
python读写文件write和flush的实现方式
2020/02/21 Python
手把手教你安装Windows版本的Tensorflow
2020/03/26 Python
python爬虫要用到的库总结
2020/07/28 Python
印度民族服装购物网站:BIBA
2019/08/05 全球购物
科颜氏香港官方网店:Kiehl’s香港
2021/03/07 全球购物
网络教育自我鉴定
2013/11/01 职场文书
三年大学自我鉴定
2014/01/16 职场文书
2014年妇女工作总结
2014/12/06 职场文书
2014年青年教师工作总结
2014/12/17 职场文书
未婚证明范本
2015/06/15 职场文书
利用Pycharm连接服务器的全过程记录
2021/07/01 Python