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

东莞网站建设公司好wordpress chrome插件

东莞网站建设公司好,wordpress chrome插件,Wordpress公网,静安网站建设哪里有#一、是什么 我们将组件间通信可以拆分为两个词: 组件通信 回顾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.yayakq.cn/news/652967/

相关文章:

  • 网站推广方式介绍一个空间开几个网站
  • 无锡网站设计哪家公司好salutation wordpress
  • 住宅城乡建设部门户网站绿色国网app
  • 暂时没有域名怎么做网站怎样留别人电话在广告上
  • 一个新网站关键词怎么做SEO优化涪陵网站建设公司
  • 买域名的网站网络推广课程培训
  • 济宁企业网站建设公共资源交易中心待遇
  • 自学网站建设哪些网站wordpress可以装在子目录
  • 苏州网站建站公司企业网站鉴赏
  • 家居设计网站推荐wordpress设置角色
  • 同一人做多个主体网站负责人wordpress 分类编号
  • 哪里有做网站技术东营网站建设怎么建设
  • 建湖做网站开发网站公司
  • 自适应网站建设需要注意什么网站建设实验报告
  • 滕州本地网站建设网站多个用户怎样建设
  • 辖网站建设 网站设计wordpress安装无法链接数据库文件
  • qt 网站开发营销策划与运营团队
  • 静态网站末班奉节做网站
  • 深圳的网站建设公司的分类是哪里有网站建设中心
  • 做非经营网站需要营业执照百度一下建设银行网站首页
  • 做网站导航站的注意点nas访问不了wordpress
  • 旅游网站源码下载ftp上传后没有网站
  • 新浪网站怎么做推广莱芜网络小说作家
  • 建设银行信用卡卡网站首页服装企业网站源码
  • 怎么建个人网站什么是网站建设方案书
  • 旅游网站模板文章广东餐饮品牌设计
  • dedecms模板站温州做网站的公司有哪些
  • 网站悬浮代码山东烟台城乡建设学校官方网站
  • 衡水企业网站设计报价烟台H5网站设计
  • 做网站怎样建立服务器dz整站网站建设