React—封装组件传递参数

1、app.js

ReactDom.render(
    <div>
        <Nav></Nav>
        <Pic title="标题aaa" cont="内容bbb"></Pic>
    </div>,
    document.getElementById('root')
)

2、Pic.js // 组件 注意起名规范,如果是关键字会报错

第一种写法:

export default class Pic extends Component {
    render () {
        return (
            <div className="pic">
                <img className="img" src={require('images/1.jpg')} alt=""/>
                <h3>{this.props.title}</h3>
                <p>{this.props.cont}</p>
            </div>
        )
    }
}

第二种写法:

export default class Pic extends Component {
    render () {
        let {title, cont} = this.props;
        return (
            <div className="pic">
                <img className="img" src={require('images/1.jpg')} alt=""/>
                <h3>{title}</h3>
                <p>{cont}</p>
            </div>
        )
    }
}
好的,我可以为您分享一下如何封装React Modal组件。 首先,您需要安装React Modal组件库。可以通过以下命令进行安装: ``` npm install react-modal ``` 接下来,您可以创建一个Modal组件并在其中封装React Modal。在组件中,您需要定义一个状态来控制Modal的显示和隐藏。这个状态可以使用useState钩子来实现。 ``` import React, { useState } from "react"; import Modal from "react-modal"; function MyModal(props) { const [isOpen, setIsOpen] = useState(false); const handleOpenModal = () => { setIsOpen(true); }; const handleCloseModal = () => { setIsOpen(false); }; return ( <> <button onClick={handleOpenModal}>打开模态框</button> <Modal isOpen={isOpen} onRequestClose={handleCloseModal} contentLabel="Modal" > <h2>这是一个模态框</h2> <p>这里可以放置模态框的内容</p> <button onClick={handleCloseModal}>关闭模态框</button> </Modal> </> ); } export default MyModal; ``` 在上面的示例中,我们定义了一个MyModal组件,并在其中封装React Modal。我们使用useState钩子来定义了一个名为isOpen的状态,它用于控制Modal的显示和隐藏。handleOpenModal和handleCloseModal函数分别用于打开和关闭Modal。我们在Modal组件中传递了三个props:isOpen,onRequestClose和contentLabel。isOpen用于控制Modal的显示和隐藏,onRequestClose用于在用户点击Modal外部时关闭Modal,contentLabel用于给Modal添加一个描述。 最后,我们在组件的返回值中渲染了一个按钮和一个Modal。我们将handleOpenModal函数绑定到按钮的onClick事件上,以便在单击按钮时打开Modal。我们在Modal中渲染了一些内容,并将handleCloseModal函数绑定到关闭按钮的onClick事件上,以便在单击关闭按钮时关闭Modal。 这样,您就可以使用封装好的Modal组件在您的React应用程序中创建模态框了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值