zoukankan      html  css  js  c++  java
  • [React] Use React.ReactNode for the children prop in React TypeScript components and Render Props

    Because @types/react has to expose all its internal types, there can be a lot of confusion over how to type specific patterns, particularly around higher order components and render prop patterns. The widest and most recommended element type is React.ReactNode, and we build up to it by explaining the edge cases.

    For render prop:

    type ButtonProps = {
      label?: string;
      children: (b: boolean) => React.ReactNode;
    };
    function App() {
      return (
        <Button>
          {isOn => (isOn ? <div> Turn off</div> : <div> Turn on</div>)}
        </Button>
      );
    }
    type ButtonProps = {
      label?: string;
      children: React.ReactNode;
    };
    type ButtonState = {
      isOn: boolean;
    };
    class Button extends React.Component<ButtonProps, ButtonState> {
      static defaultProps = {
        label: "Hello World!"
      };
      state = {
        isOn: false
      };
    
      toggle = () => this.setState({ isOn: !this.state.isOn });
    
      render() {
        const { label, children } = this.props;
        const { isOn } = this.state;
        const style = {
          backgroundColor: isOn ? "red" : "green"
        };
        return (
          <button style={style} onClick={this.toggle}>
            {children(isOn)}
          </button>
        );
      }
    }

    For React children projection:

    type ButtonProps = {
      label?: string;
      children: React.ReactNode;
    };
  • 相关阅读:
    Android之旅七 Service简介
    使用CALayer实现图像镜面效果
    hdu4587 TWO NODES
    js Ajax
    SQL Server 2008数据库备份与恢复
    11g R2单实例手工建库
    needtrue需要真实的答案
    字符编码,pyton中的encode,decode,unicode()
    用java源代码学数据结构<七>: BST
    SQL MIN() 函数
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10610597.html
Copyright © 2011-2022 走看看