当前位置: 首页 > news >正文

江苏自助建站平台东莞全网营销推广

江苏自助建站平台,东莞全网营销推广,安庆市住房和城乡建设局网站,ps制作个性字网站#一、是什么 我们将组件间通信可以拆分为两个词: 组件通信 回顾Vue系列 (opens new window)的文章,组件是vue中最强大的功能之一,同样组件化是React的核心思想 相比vue,React的组件更加灵活和多样,按照不同的方式可…

#一、是什么

我们将组件间通信可以拆分为两个词:

  • 组件
  • 通信

回顾Vue系列 (opens new window)的文章,组件是vue中最强大的功能之一,同样组件化是React的核心思想

相比vueReact的组件更加灵活和多样,按照不同的方式可以分成很多类型的组件

而通信指的是发送者通过某种媒体以某种格式来传递信息到收信者以达到某个目的,广义上,任何信息的交通都是通信

组件间通信即指组件通过某种方式来传递信息以达到某个目的

#二、如何通信

组件传递的方式有很多种,根据传送者和接收者可以分为如下:

  • 父组件向子组件传递
  • 子组件向父组件传递
  • 兄弟组件之间的通信
  • 父组件向后代组件传递
  • 非关系组件传递

#父组件向子组件传递

由于React的数据流动为单向的,父组件向子组件传递是最常见的方式

父组件在调用子组件的时候,只需要在子组件标签内传递参数,子组件通过props属性就能接收父组件传递过来的参数

function EmailInput(props) {return (<label>Email: <input value={props.email} /></label>);
}const element = <EmailInput email="123124132@163.com" />;

#子组件向父组件传递

子组件向父组件通信的基本思路是,父组件向子组件传一个函数,然后通过这个函数的回调,拿到子组件传过来的值

父组件对应代码如下:

class Parents extends Component {constructor() {super();this.state = {price: 0};}getItemPrice(e) {this.setState({price: e});}render() {return (<div><div>price: {this.state.price}</div>{/* 向子组件中传入一个函数  */}<Child getPrice={this.getItemPrice.bind(this)} /></div>);}
}

子组件对应代码如下:

class Child extends Component {clickGoods(e) {// 在此函数中传入值this.props.getPrice(e);}render() {return (<div><button onClick={this.clickGoods.bind(this, 100)}>goods1</button><button onClick={this.clickGoods.bind(this, 1000)}>goods2</button></div>);}
}

#兄弟组件之间的通信

如果是兄弟组件之间的传递,则父组件作为中间层来实现数据的互通,通过使用父组件传递

class Parent extends React.Component {constructor(props) {super(props)this.state = {count: 0}}setCount = () => {this.setState({count: this.state.count + 1})}render() {return (<div><SiblingAcount={this.state.count}/><SiblingBonClick={this.setCount}/></div>);}
}

#父组件向后代组件传递

父组件向后代组件传递数据是一件最普通的事情,就像全局数据一样

使用context提供了组件之间通讯的一种方式,可以共享数据,其他数据都能读取对应的数据

通过使用React.createContext创建一个context

 const PriceContext = React.createContext('price')

context创建成功后,其下存在Provider组件用于创建数据源,Consumer组件用于接收数据,使用实例如下:

Provider组件通过value属性用于给后代组件传递数据:

<PriceContext.Provider value={100}>
</PriceContext.Provider>

如果想要获取Provider传递的数据,可以通过Consumer组件或者或者使用contextType属性接收,对应分别如下:

class MyClass extends React.Component {static contextType = PriceContext;render() {let price = this.context;/* 基于这个值进行渲染工作 */}
}

Consumer组件:

<PriceContext.Consumer>{ /*这里是一个函数*/ }{price => <div>price:{price}</div>}
</PriceContext.Consumer>

#非关系组件传递

如果组件之间关系类型比较复杂的情况,建议将数据进行一个全局资源管理,从而实现通信,例如redux

http://www.tj-hxxt.cn/news/111424.html

相关文章:

  • 建设银行普卡申请网站太原优化排名推广
  • 简述网站建设优劣的评价标准深圳网站制作公司
  • 做网站需要审核资质吗软件开发工程师
  • 资讯是做网站还是公众号深圳网络营销外包公司推荐
  • 哪里找免费网站高端网站定制公司
  • 河南高端网站疫情最新资讯
  • 常州全景网站制作汕头百度推广公司
  • 青海做网站直通车关键词优化口诀
  • ECSHOP网站开发中心web网址
  • 中企动力科技股份有限公司石家庄分公司武汉百度网站优化公司
  • 延平区城乡建设和旅游局网站做网销的一天都在干嘛
  • 邢台123网站优化网站排名方法教程
  • html5 手机网站模版谷歌paypal官网注册入口
  • 老师找学生做网站是什么心态提高网站流量的软文案例
  • 做php网站教程视频教程网站域名解析ip
  • 莆田制作网站企业百度竞价防软件点击软件
  • 河北通信网站建设怎么弄自己的网站
  • 美工设计网页培训太原seo网络优化招聘网
  • 一级a做愛视频网站品牌推广和营销推广
  • 网站开发 博客semir是什么品牌
  • 书籍网站设计seo交流中心
  • 成都公司网站设计永久免费跨境浏览app
  • 沂南做网站要怎么做网络推广
  • 网站文章收录懂得网站推广
  • 网站开发的关系图和e-r图2021百度新算法优化
  • 网站免费注册会员怎么做百度营销平台
  • 网站开发人员职位描述免费开通网站
  • 做外贸需要什么样的网站免费投放广告的平台
  • 合肥市网站建设搜图片找原图
  • 传统的网站开发模式seo排名的影响因素有哪些