React Portals的使用

某些情况下,我们希望渲染的内容独立于父组件,甚至是独立于当前挂载到的DOM元素中(默认都是挂载到id为root的DOM元 素上的)。

Portal 提供了一种将子节点渲染到存在于父组件以外的 DOM 节点的优秀的方案:

  • 第一个参数(child)是任何可渲染的 React 子元素,例如一个元素,字符串或 fragment;
  • 第二个参数(container)是一个 DOM 元素;
    在这里插入图片描述

通常来讲,当你从组件的 render 方法返回一个元素时,该元素将被挂载到 DOM 节点中离其最近的父节点:然而,有时候将子元素插入到 DOM 节点中的不同位置也是有好处的:
在这里插入图片描述

Modal组件案例

比如说,我们准备开发一个Modal组件,它可以将它的子组件渲染到屏幕的中间位置:

  • 步骤一:修改index.html添加新的节点
    在这里插入图片描述

  • 步骤二:编写这个节点的样式
    在这里插入图片描述
    在这里插入图片描述

  • 步骤三:编写组件代码
    在这里插入图片描述

import React, {PureComponent} from 'react';
import ReactDom from 'react-dom'
class Modal extends PureComponent {
    render() {
        return ReactDom.createPortal(
            this.props.children,
            document.getElementById('modal')
        )
    }
}
class Home extends PureComponent {
    render() {
        return (
            <div>
                <h2>Home</h2>
                <Modal>
                    <h2>Title</h2>
                </Modal>
            </div>
        );
    }
}
class App extends PureComponent {
    render() {
        return (
            <div>
                <Home />
            </div>
        );
    }
}
export default App;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值