当前位置: 移动技术网 > IT编程>开发语言>Java > 详解React的回调渲染模式

详解React的回调渲染模式

2020年09月11日  | 移动技术网IT编程  | 我要评论
一、一个简单的小例子1.父组件<twitter username='tylermcginnis33'> {(user) => user === null ? <loa

一、一个简单的小例子

1.父组件

<twitter username='tylermcginnis33'>
 {(user) => user === null
  ? <loading />
  : <badge info={user} />}
</twitter>

2.子组件框架

import react, { component, proptypes } from 'react'
import fetchuser from 'twitter'
// fetchuser take in a username returns a promise
// which will resolve with that username's data.
class twitter extends component {
 // finish this
}

3.子组件具体实现

import react, { component, proptypes } from 'react';
import fetchuser from 'twitter';
class twitter extends component {
 state = {
  user: null,
 }
  static proptypes = {
  username: proptypes.string.isrequired,
 }
  componentdidmount() {
  fetchuser(this.props.username).then(user => this.setstate({user}));
 }
  render() {
  return this.props.children(this.state.user);
 }
}

这种模式的优势在于将父组件与子组件解耦和,父组件可以直接访问子组件的内部状态而不需要再通过 props 传递,这样父组件能够更为方便地控制子组件展示的 ui 界面。譬如产品经理让我们将原本展示的 badge 替换为 profile,我们可以轻易地修改下回调函数即可:

<twitter username='tylermcginnis33'>
 {(user) => user === null
  ? <loading />
  : <profile info={user} />}
</twitter>

到此这篇关于详解react的回调渲染模式的文章就介绍到这了,更多相关react 回调渲染内容请搜索移动技术网以前的文章或继续浏览下面的相关文章希望大家以后多多支持移动技术网!

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网