前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >React的Portal是干什么的?

React的Portal是干什么的?

原创
作者头像
Learn-anything.cn
发布2021-11-28 06:18:07
6220
发布2021-11-28 06:18:07
举报
文章被收录于专栏:learn-anything.cn
一、解决了什么问题?

React节点默认渲染到父节点下,Portal可以让节点渲染到非父节点的其他节点下面。Portal适用场景:当子组件需要从视觉上“跳出”其容器时,譬如对话框、悬浮卡、提示框等。

二、用法说明
1、React正常渲染节点
代码语言:txt
复制
render() {
    // React 挂载了一个新的 div,并且把子元素渲染其中
    return (
        <div>
            {this.props.children}
        </div>
    );
}
2、Portal渲染节点
代码语言:txt
复制
render() {
    // React 并*没有*创建一个新的 div。它只是把子元素渲染到 `domNode` 中。
    // `domNode` 是一个可以在任何位置的有效 DOM 节点。
    return ReactDOM.createPortal(
        this.props.children,
        domNode
    );
}
三、参考链接:

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、解决了什么问题?
  • 二、用法说明
    • 1、React正常渲染节点
      • 2、Portal渲染节点
      • 三、参考链接:
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档