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

站点介绍

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

React的fragment

abzzp 2025-04-10 369 0条评论 前端 React

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

发布于2024-07-04

在React中,当你需要在组件的根元素下渲染多个子节点时,但又不想引入额外的DOM元素作为容器,你可以使用Fragment。Fragment允许你将一组子节点组合在一起而不添加额外节点到DOM中。

下面是一个使用Fragment的例子:

import React,{PureComponent,Fragment} from "react";

export class App extends PureComponent {
    constructor(){
        super()
        
        this.state = {
            sections:[
                {title:"哈哈哈",content:"我是内容,哈哈哈"},
                {title:"呵呵呵",content:"我是内容,呵呵呵"},
                {title:"嘿嘿嘿",content:"我是内容,嘿嘿嘿"},
                {title:"嘻嘻嘻",content:"我是内容,嘻嘻嘻"},
            ]
        }
    }
    
    render(){
        const { sections } = this.state
        
        return (
            <>
            <h2>我是App的标题</h2>
            <p>我是App的内容,哈哈哈</p>
            <hr />
            {
                sections.map(item=>{
                    return (
                        <Fragment key={item.title}>
                            <h2>{item.title}</h2>
                            <p>{item.content}</p>
                        </Fragment>
                    )
                })
            }
            </>
        )
    }
}

export default App

在上面的例子中,<></>是Fragment的简写形式。你也可以使用React.Fragment来达到同样的效果:

import React,{PureComponent,Fragment} from "react";

export class App extends PureComponent {
    constructor(){
        super();

        this.state = {        
        }
    }    
    render(){
        return (
            <React.Fragment>
                {/* 这里是你的子节点 */}
            </React.Fragment>
        )
    }
}

在React中,Fragment是一个特殊的组件,它没有对应的DOM元素。它只是用来将多个子节点组合在一起,而不会添加额外的DOM元素到DOM树中。最后我们附上浏览器上的效果图:

React的fragment

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

评论(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咨询交流......
点击小铃铛关闭
配色方案