这篇文章给大家介绍React中怎么实现Portal可复用组件,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
创新互联公司长期为成百上千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为恩平企业提供专业的成都网站设计、做网站、成都外贸网站建设公司,恩平网站改版等技术服务。拥有十余年丰富建站经验和众多成功案例,为您定制开发。
1、通常你的网站只有一个root
<body> <div id="root"></div> </body>
2、使用Portal之后,可以变成下面这样
<body> <div id="root"></div> <div id="portal"></div> </body>
Portal高阶组件封装
Portal的demo在官网上可以看到,而我们要实现的是将它封装成一个可以复用的组件。
目标
不需要手动在body下面增加HTML,通过组件自己去创建。
<CreatePortal id, //可以传入id className, //可以传入className style //可以传入style > 此处插入div或者react组件 </CreatePortal>
实现方案
1、创建一个createPortal函数,该函数将会return一个Portal组件
function createPortal() { } export default createPortal()
2、创建Portal组件
import React from 'react' import ReactDOM from 'react-dom' import PropTypes from 'prop-types' function createPortal() { class Portal extends React.Component{ } return Portal } export default createPortal()
3、render函数实现,用createPortal创建portal。
render() { return ReactDOM.createPortal( this.props.children, this.el ) }
4、componentDidMount函数实现,将dom添加到body下面
componentDidMount() { document.body.appendChild(this.el); }
5、componentWillUnmount函数实现,清除DOM结构
componentWillUnmount() { document.body.removeChild(this.el) }
6、实现props,包括id、className、style
constructor(props) { super(props) this.el = document.createElement('div') if (!!props) { this.el.id = props.id || false if (props.className) this.el.className = props.className if (props.style) { Object.keys(props.style).map((v) => { this.el.style[v] = props.style[v] }) } document.body.appendChild(this.el) } }
7、完整代码
import React from 'react' import ReactDOM from 'react-dom' import PropTypes from 'prop-types' function createPortal() { class Portal extends React.Component{ constructor(props) { super(props) this.el = document.createElement('div') if (!!props) { this.el.id = props.id || false if (props.className) this.el.className = props.className if (props.style) { Object.keys(props.style).map((v) => { this.el.style[v] = props.style[v] }) } document.body.appendChild(this.el) } } componentDidMount() { document.body.appendChild(this.el); } componentWillUnmount() { document.body.removeChild(this.el) } render() { return ReactDOM.createPortal( this.props.children, this.el ) } } Portal.propTypes = { style: PropTypes.object } return Portal } export default createPortal()
关于React中怎么实现Portal可复用组件就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
当前名称:React中怎么实现Portal可复用组件
文章位置:https://www.cdcxhl.com/article42/posihc.html
成都网站建设公司_创新互联,为您提供网页设计公司、网站导航、动态网站、手机网站建设、网站策划、定制开发
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联