• [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;
    };
  • 相关阅读:
    随意输入一串字符串,显示出现次数最多的字符,以及出现次数
    类似QQ的聊天工程
    Java基础语法
    Java安装环境
    创建纯洁的TableViewCell
    从gitlab下载好cocoapods中遇到的问题
    tableview隐藏多余分割线
    UIBarButtonItem变弹簧
    Dictionary中的结构体转出来
    tableviewcell不允许点击
  • 原文地址:https://www.cnblogs.com/Answer1215/p/10610597.html
Copyright © 2020-2023  润新知