最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

react开发教程之React 组件之间的通信方式

来源:懂视网 责编:小采 时间:2020-11-27 22:32:56
文档

react开发教程之React 组件之间的通信方式

react开发教程之React 组件之间的通信方式:这两天学习了React感觉组件通信这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。 父子组件通讯 通讯手段 这是最常见的通信方式,父组件只需要将子组件需要的props传给子组件,子组件直接通过this.props来使用。 通讯内容 更多要提的是
推荐度:
导读react开发教程之React 组件之间的通信方式:这两天学习了React感觉组件通信这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。 父子组件通讯 通讯手段 这是最常见的通信方式,父组件只需要将子组件需要的props传给子组件,子组件直接通过this.props来使用。 通讯内容 更多要提的是

这两天学习了React感觉组件通信这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。

父子组件通讯

通讯手段

这是最常见的通信方式,父组件只需要将子组件需要的props传给子组件,子组件直接通过this.props来使用。

通讯内容

更多要提的是如何合理的设置子组件的props,要想将子组件设计成一个复用性强的通用组件,需要将能够复用的部分抽象出来,抽象出来的props有两种形成,一种是简单的变量,另一种是抽象出来处理某种逻辑函数。

以Header 组件为例

//HeaderBar.jsx 子组件

import React, { Component } from 'react';

class Header extends Component {
 constructor() {
 super();
 this.handleClick = (e) => {
 console.log(this)
 }
 }

 renderLeftComponent() {

 let leftDOM = {};
 if (this.props.renderLeftComponent) {
 return this.props.renderLeftComponent();
 }

 if (this.props.showBack) {
 let backFunc = this.props.onBack || this.goBack;
 leftDOM = (<a onClick={backFunc.bind(this)}><i className="icon left-icon icon-left-arrow"></i></a>);
 }
 return leftDOM;
 }
 

 renderRightComponent() {
 if (this.props.renderRightComponent) {
 return this.props.renderRightComponent();
 }
 }

 goBack() {
 alert("返回上一页")
 }

 render() {
 return (
 <header className="header-bar">
 {this.renderLeftComponent()}
 <span>{this.props.title || '滴滴'}</span>
 {this.renderRightComponent()}
 </header>
 );
 }
}

export default Header;

//父亲组件部分代码App.jsx
import HeaderBar from "./components/Header";

let leftIcon = function () {
 return (
 <a><i className="icon left-icon icon-left-haha"></i>左边按钮</a>
 )
}
class App extends Component {

 render() {
 return (
 <div className="App">
 <HeaderBar title="滴滴打车" renderLeftComponent={leftIcon} />
 </div>
 );
 }
}

子父组件通讯

父-子组件通信的手段是通过子组件的props是子组件用父组件的东西,子-父组件通信,是父组件用子组件的东西,暂时了解的两种方法

利用回调函数

父组件通过props传递一个方法给子组件,子组件通过props方法将子组件数据传递给父组件

利用ref

父组件通过refs调用子组件的属性

跨级组件通信

在React中当一个属性反复使用并且存在与好几个子组件中的时候,这个时候我们如果通过props一级一级传递的话可以实现多层级访问,但是这样出现一个问题就是会使代码非常混乱,在React中国年,我们还可以使用 context 来实现跨级父子组件间的通信;

在react中context称为虫洞

// Component 父级
class parentComponent extends React.Component {
 
 // add the following property
 static childContextTypes = {
 color: React.PropTypes.string
 }
 
 // 添加下面方法
 getChildContext() {
 return {
 color: "#f00"
 }
 }
 
 render() {
 <div>
 <Child1 />
 </div>
 }
}


// Component Child1
class Child1 extends React.Component {
 // 添加下面属性
 static contextTypes = {
 color: React.PropTypes.string
 }
 
 render() {
 <div>{this.context.color}</div>
 }
}

同级组件通信

同级组件之间的通信还是需要通过父组件作为中介,利用多次父-子组件通信,项目中将需要传递的数据放在了父组件的state中,变动时可以自动的同步传递。

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

react开发教程之React 组件之间的通信方式

react开发教程之React 组件之间的通信方式:这两天学习了React感觉组件通信这个地方知识点挺多的,而且很重要,所以,今天添加一点小笔记。 父子组件通讯 通讯手段 这是最常见的通信方式,父组件只需要将子组件需要的props传给子组件,子组件直接通过this.props来使用。 通讯内容 更多要提的是
推荐度:
标签: 的方法 开发 方式
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top