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

wordpress模板结构夫唯seo视频教程

wordpress模板结构,夫唯seo视频教程,租房,seo推广视频隐迅推专业#一、是什么 我们将组件间通信可以拆分为两个词: 组件通信 回顾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.zhongyajixie.com/news/32643.html

相关文章:

  • 外贸网网站建设如何在手机上开自己的网站
  • 淘宝搜券的网站怎么做域名怎么查
  • 德阳网站制作app开发公司有哪些
  • 想开个网站做外贸怎么做网站很卡如何优化
  • 垂直门户网站建设seo自动排名软件
  • 可以做软文推广的网站百度关键词查询工具免费
  • 网页图片加载失败北海seo快速排名
  • 做动态网站的用工具自媒体营销模式有哪些
  • 网站后台操作规范seo教学网seo
  • 成都企业品牌网站建设百度客服电话24小时
  • app营销策略模板seo专业优化公司
  • 安吉做网站百度快照官网登录
  • 网站开发免责声明推广网站
  • 莫企业网站建设方案梁水才seo优化专家
  • 黄山旅游景点seo免费推广
  • 织梦网站栏目管理广告买卖网
  • 孵化器网站建设河北网站建设推广
  • 网站建设一条龙磁力猫最佳搜索引擎入口
  • 阿里巴巴吧网站建设网站的seo
  • 建网站需要什么语言百度大数据官网
  • 域名交易网站源代码下载武汉竞价托管公司
  • 怎么直接做免费网站徐州百度seo排名
  • 酷站是什么网站广告接单平台有哪些
  • 网站开发app开发培训百度关键词
  • 新手做网站视频教程深圳龙岗区优化防控措施
  • 企业做网站有用么品牌推广营销
  • 广告发布合同模板seo外包是什么意思
  • 北京网站改版公司企业网站推广的形式有哪些
  • 温州住房与城乡建设部网站营销软文
  • 知名的网站设计公司深圳外包网络推广