程序员鸡皮
文章 分类 评论
102 3 28

站点介绍

一名PHP全栈程序员的日常......

React中的Portals

abzzp 2025-04-09 396 0条评论 前端 React

首页 / 正文
本站是作为记录一名北漂程序员编程学习以及日常的博客,欢迎添加微信BmzhbjzhB咨询交流......

发布于2024-07-04

Portals 提供了一种很好的将子节点渲染到父组件以外的 DOM 节点的方案。
通常,子组件会被嵌套在父组件的 DOM 树中。但是,在某些情况下,我们可能需要将子组件渲染到父组件以外的 DOM 节点中。这时候,我们就可以使用 Portals 来实现。
Portals 可以将子组件渲染到父组件以外的 DOM 节点中,这对于一些特殊的场景非常有用。
我们可以使用 Portals 来实现一些特殊的组件,例如:
import React, { PureComponent } from "react";
import { createPortal } from "react-dom";
import Modal from "./Modal";

export class App extends PureComponent{
    render(){
        return (
            <div className="app">
                <h1>App H1</h1>
                {
                    createPortal(<h2>App H2</h2>,document.querySelector("#why"))
                }
                
                {/* 2.Modal组件 */}
                <Modal>
                    <h2>我是标题</h2>
                    <p>我是内容,哈哈哈</p>
                </Modal>
            </div>
        )
    }
}

export default App
在上面的代码中,我们使用了 createPortal 方法来将子组件渲染到父组件以外的 DOM 节点中。其中,createPortal 方法接受两个参数:子组件和目标 DOM 节点。

接着我们来看一下 Modal 组件的实现:

import React, { PureComponent } from 'react'
import { createPortal } from "react-dom"

export class Modal extends PureComponent {
  render() {
    return createPortal(this.props.children, document.querySelector("#modal"))
  }
}

export default Modal

在上面的代码中,我们使用了 createPortal 方法来将子组件渲染到父组件以外的 DOM 节点中。其中,createPortal 方法接受两个参数:子组件和目标 DOM 节点。

注意:在使用 Portals 时,我们需要注意以下几点:

  1. Portals 只能用于渲染到父组件以外的 DOM 节点中。
  2. Portals 只能用于渲染 React 元素,不能用于渲染字符串或其他类型的元素。
  3. Portals 只能用于渲染到已经存在的 DOM 节点中,不能用于创建新的 DOM 节点。

总结:Portals 是 React 中非常有用的一个特性,它可以将子组件渲染到父组件以外的 DOM 节点中,这对于一些特殊的场景非常有用。
接着最后我们附上浏览器上的效果图:

React中的Portals

感谢大家观看,我们下次再见!

评论(0)

最新评论

  • abzzp

    以后焦虑了或者迷茫了记得回来看看[[流泪]]

  • 三十三瀑布

    我非常喜欢 出行博客。鼓舞人心查看路线。

  • 天星碼頭

    你们的博客 百分百 帮助选择路线。坚持!

  • 日落鼓掌

    信息丰富的 出行资源! 越来越棒!

  • digital banking

    My brother suggested I might like this blog. He was entirely right. This post actually made my day. You cann't imagine just how much time I had spent for this information! Thanks!

  • 碧海藍灣

    我热爱, 写得很实在。你的博客 就是 最好的例子。很出色。

  • digital banking

    I've learn several good stuff here. Certainly price bookmarking for revisiting. I surprise how so much effort you put to make such a great informative website.

  • fintechbase

    It's not my first time to pay a visit this web page, i am visiting this website dailly and get good facts from here every day.

  • fintechbase

    Hello, i think that i saw you visited my site so i got here to go back the want?.I'm trying to find things to improve my web site!I suppose its adequate to use a few of your concepts!!

  • fintechbase

    Touche. Outstanding arguments. Keep up the great effort.

日历

2026年01月

    123
45678910
11121314151617
18192021222324
25262728293031

文章目录

站点公告
本站是作为记录一名北漂程序员编程学习以及日常的博客,欢迎添加微信BmzhbjzhB咨询交流......
点击小铃铛关闭
配色方案