微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

关于react 的render props 如何使用

最近开始复习react内容,看到这块的时候想起来以前也没用过,就写了一个小例子看看,代码如下

import React from 'react';

class Tip extends React.Component{
    render() {
        const pos = this.props.pos;
        console.log('ps', pos)
        return (
            <div style={{position: 'fixed', backgroundColor: "#234567",left:pos.left, top: pos.top, visibility: pos.vis}}>
                <h1>{pos.title}</h1>
                <p>{pos.content}</p>
            </div>
        )
    }
}


class Btn extends React.Component{
    constructor(props) {
        super(props);
        this.state = {
            left: '200px',
            top: '50px',
            vis: 'hidden',
            title: '这是title',
            content: '这是content'
        }
        this.clickBtn = this.clickBtn.bind(this)
    }

    clickBtn() {
        let viss = this.state.vis === 'hidden' ?  'visible' : 'hidden';
        this.setState({
            vis: viss
        })
    }

    render() {
        return (
            <div style={{width:'80px', height:'32px', backgroundColor: '#892749'}} onClick={this.clickBtn}>
                点击按钮
                {this.props.render(this.state)}
            </div>
        )
    }
}

class TipShow extends React.Component{
    render() {
        
        return (
            <>
                <Btn render={pos => {
                    console.log(pos)
                    return <Tip pos={pos} ></Tip>
                }}>
                    
                </Btn>
            </>
        )
    }
}

export default TipShow

 

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐