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

做货品批发的网站都有哪些如何制作网站二维码

做货品批发的网站都有哪些,如何制作网站二维码,amazon affiliate wordpress,手机制作游戏的软件相关文章: React Context的使用方法 react Provider Consumer 使用方法 1. 是什么 我们将组件间通信可以拆分为两个词: 组件通信 组件是vue中最强大的功能之一,同样组件化是React的核心思想 相比vue,React的组件更加灵活和多样…

相关文章:
React Context的使用方法
react Provider Consumer 使用方法

1. 是什么

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

  • 组件
  • 通信

组件是vue中最强大的功能之一,同样组件化是React的核心思想
相比vue,React的组件更加灵活和多样,按照不同的方式可以分成很多类型的组件
而通信指的是发送者通过某种媒体以某种格式来传递信息到收信者以达到某个目的,广义上,任何信息的交通都是通信
组件间通信即指组件通过某种方式来传递信息以达到某个目的

2. 如何通信

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

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

2.1 父组件向子组件传递

由于React的数据流动为单向的,父组件向子组件传递是最常见的方式
父组件在调用子组件的时候,只需要在子组件标签内传递参数,子组件通过props属性就能接收父组件传递过来的参数

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

2.2 子组件向父组件传递的

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

//父组件代码
class Parents extends Component {constructor() {super();this.state = { price: 0 };}getPrice(e) {this.setState({price: e }); }render() {return ( <div><div>price: {this.state.price}</div> {/*向子组件传入一个函数 */}<Child getPrice={this.getPrice.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> ); }}

2.3 兄弟组件之间的通信

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

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

2.4 父组件向后代组件传递

父组件向后代组件传递数据是一件最普通的事情,就像全局数据一样
使用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>

2.5 非关系组件传递

如果组件之间关系类型比较复杂的情况,建议将数据进行一个全局资源管理,从而实现通信,例如redux。关于redux的使用后续再详细介绍

3. 总结

由于React是单向数据流,主要思想是组件不会改变接收的数据,只会监听数据的变化,当数据发生变化时它们会使用接收到的新值,而不是去修改已有的值因此,可以看到通信过程中,数据的存储位置都是存放在上级位置中

http://www.yidumall.com/news/44360.html

相关文章:

  • 做网站的工具 论坛浙江seo推广
  • 移动互联网网站开发技术推广普通话文字素材
  • 陕西手机网站建设seo值是什么意思
  • 网站开发视频资源放哪儿郑州网站建设专业乐云seo
  • 外贸建站效果广东疫情最新通报
  • 视频插入网站自学seo能找到工作吗
  • 怎么在百度知道做公司网站汕头网站建设公司哪个好
  • 中国建设银行官网站纪念币seo学习
  • 做网站用虚拟服务器可以吗宁波网站推广找哪家公司
  • 网站上循环滚动的友情链接怎么做深圳网站营销seo费用
  • wordpress物联网插件百度禁止seo推广
  • 衢州酷网站制作baud百度一下
  • dw网页制作源代码seo是一种利用搜索引擎的
  • 松江品划做网站公司百度登录页
  • 自己做h5网站百度互联网营销顾问
  • 雄安网站建设多少钱seo优化百度技术排名教程
  • 网站内容管理系统cms广州公司关键词网络推广
  • 湖北商城网站建设多少钱seo是指什么岗位
  • 广州一流高校建设网站网络营销的工具和方法有哪些
  • WordPress多语言多站点优化网站做什么的
  • 无备案网站加速平台推广是什么工作
  • 做网站制作的摘要网站页面分析作业
  • 赣州网站制作抖音seo搜索引擎优化
  • 做网站费用会计科目全网投放广告的渠道有哪些
  • 天津做网站贵吗网络营销软文范例300字
  • 色彩搭配 网站最佳搜索引擎
  • 重庆宣传网站怎么做推广普通话宣传语
  • 浏览器网页打不开怎么解决北京网络推广公司wyhseo
  • 小企业做网站选那种google搜索引擎入口下载
  • 怎么做网站销售超级seo工具