Fragments

Loading "Fragments"
๐Ÿฆ‰ One feature of JSX that you'll find useful is called "React Fragments".
React Fragments allow you to group multiple elements without adding an extra DOM node. This lets you return multiple elements side-by-side from a component without needing a wrapper div. It's useful for avoiding unnecessary markup that could affect styling or layout.
We have currently the following code:
<div className="container">
	<p>Here's Sam's favorite food:</p>
	<ul className="sams-food">
		<li>Green eggs</li>
		<li>Ham</li>
	</ul>
</div>
We want to do the same thing as above, except we don't want the container div. So, we want to just create:
<p>Here's Sam's favorite food:</p>
<ul class="sams-food">
	<li>Green eggs</li>
	<li>Ham</li>
</ul>
In React, we do this with <React.Fragment>. Replace the <div className="container"> with a fragment and inspect the DOM to notice that the elements are both rendered as direct children of root.
๐Ÿ’ฐ TIP: Fragments are common enough that there's a syntax shortcut for them. You can open with <> and close with </>, so:
element = <React.Fragment>this is in a fragment</React.Fragment>
// is the same as:
element = <>this is in a fragment</>
๐Ÿ‘จโ€๐Ÿ’ผ We want to get rid of the <div className="container"> we have in there, but we need to keep the <p> and <ul> next to each other. Figure out how to make that work.
๐Ÿ’ฏ As a little extra part of this, try to figure out why <React.Fragment> is needed at all. Might help if you look at what this looks like using createElement rather than JSX. As I said, understanding how JSX compiles to createElement really helps improve your capabilities with JSX!

Please set the playground first

Loading "Fragments"
Loading "Fragments"
Login to get access to the exclusive discord channel.
  • ๐ŸŽฃHooks
    General
    Terminal error when setting playground
    Natiq ๐Ÿš€:
    Every time I click on the "SET TO PLAYGROUND", the app stops with the following error. How can I fix...
    1 ยท 2 days ago
  • โš›๏ธFundamentals
    Playground + live reload?
    Jonas ๐Ÿš€:
    I'm just starting the epic react course, and I'm struggling with how to use the playground. I've wat...
    • โœ…1
    2 ยท 10 days ago
  • General
    Welcome to EpicReact.dev! Say Hello ๐Ÿ‘‹
    Kent C. Dodds โ—† ๐Ÿš€๐Ÿ†๐ŸŒŒ:
    Welcome to the first of many posts in the EpicReact.dev channel! Take a moment to introduce yourself...
    • ๐Ÿš€6
    59 ยท 4 days ago
  • โš›๏ธFundamentals
    Raw API - CORS policy error
    a:
    Hello there! I have this strange error in the console in my Raw API exercices and nothing is displa...
    • โœ…2
    3 ยท 6 months ago
  • General
    error when installing the MCP server
    DBattou ๐Ÿš€:
    I tried to install the mcp server by following the instructions on the blog post here -> https://www...
    • ๐Ÿ‘1
    • โœ…1
    8 ยท 2 months ago
  • โš›๏ธFundamentals
    02. Raw API / 01. Create React Elements
    Tolu:
    When I set the playground in this lesson there's no 'react.js' and '/react-dom/client.js' files add...
    • โœ…1
    3 ยท 2 months ago
  • General
    Interviews with Experts -> Start Watching CTA gives regional restricted license error
    .shreyasvaidya ๐Ÿš€:
    I have purchased my course from India with the regional pricing method, and I am trying to watch the...
    • โœ…1
    4 ยท 3 months ago
  • General
    You are offline - warning
    marianavinyolas ๐ŸŒŒ ๐Ÿš€:
    Hi there! Today I want to start with the Advanced Patterns workshop, but after clone and run the rep...
    • โœ…1
    3 ยท 4 months ago
  • General
    โš›๏ธFundamentals
    Clicking on index.html when start opens in Terminal and not on the editor.
    Waddle ๐Ÿš€:
    Hello, just starting out with this and noticed that when I click on the 'index.html' file as display...
    • โœ…2
    1 ยท 4 months ago
  • โš›๏ธFundamentals
    04. Custom components / 02. Raw API
    mpirrocco ๐Ÿš€:
    Am getting an error with this code which I believe is exactly like the solution, so I can't figure o...
    • โœ…1
    5 ยท 4 months ago
  • General
    Am I following the course in the proper way?
    bauti ๐Ÿš€ ๐ŸŒŒ:
    The way im doing things in epic-react is: Clone the repo for the module i want to do (for example a...
    • โœ…1
    3 ยท 4 months ago
  • ๐ŸŽฃHooks
    General
    VSCode imports from wrong source
    mathemaat ๐Ÿš€:
    I encountered something silly that threw me off for a minute or two. I was working on the Tic Tac To...
    • โœ…1
    1 ยท 5 months ago
  • General
    Terminal Errors When Running Workshop App
    Giovanni ๐Ÿš€:
    Hello guys, I am facing an issue with the Workshop App, that basically I get this message over and...
    • โœ…1
    3 ยท 5 months ago
  • General
    Launch editor error: spawn code ENOENT
    Andrew Elans ๐ŸŒŒ ๐Ÿš€:
    Clicking index.html gives this error in VS Code. Both from Chrome and Safari. Anyone?
    • โœ…2
    6 ยท 9 months ago
  • โš›๏ธFundamentals
    Fundamentals 9.1 - 9.3 Error Boundary tests need update
    mathemaat ๐Ÿš€:
    In the video on Error Boundaries (Fundamentals 9.2), the error being caught is `Cannot read properti...
    • โœ…1
    5 ยท 5 months ago
  • โš›๏ธFundamentals
    ReferenceError: File is not defined
    Tom_K ๐Ÿš€ ๐ŸŒŒ:
    i get this error trying to access the mock server (/onboarding) ReferenceError: File is not define...
    • โœ…1
    8 ยท 6 months ago
  • General
    Cannot connect workshop app
    Philipp ๐Ÿš€:
    I try to connect with my Company MacBook and get the following error ๐Ÿ˜ฆ There was an error: unable t...
    • โœ…1
    5 ยท 6 months ago
  • โš›๏ธFundamentals
    TypeScript 05. Reduce Duplication
    Elliott ๐Ÿš€ ๐ŸŒŒ:
    Hi everyone, hoping you have all had a good Christmas, and happy new year to you. Apologies if this ...
    • โœ…1
    1 ยท 6 months ago
  • General
    Problem generating the diff
    mikeyjmcc ๐Ÿš€:
    I am not sure what has changed but I am now receiving errors that the diff cannot be generated. This...
    • โœ…2
    1 ยท 6 months ago
  • General
    Problem with playground
    Xrayoptions ๐Ÿš€:
    Problem section doesn't show <@105755735731781632> how to fix it ?
    • โœ…1
    9 ยท 6 months ago
  • โš›๏ธFundamentals
    4. Custom Components / 02. Raw API
    Jakub ๐Ÿš€ ๐ŸŒŒ:
    Hey I noticed something weird in content test in Custom Components / Raw API: > Proper elements are ...
    • โœ…1
    4 ยท 7 months ago
  • General
    How to run tests in IDE?
    anonymousBlack10:
    Is it possible to run the tests from the IDE or are they setup to be run just from the browser? Some...
    • โœ…1
    1 ยท 7 months ago
  • General
    Launch editor error: Could not open 'index.html' from:'playground' in the editor.
    Japhet ๐Ÿš€ ๐Ÿ† ๐ŸŒŒ:
    I'm encountering an issue when trying to open a link from the file list. The error message I receive...
    • โœ…1
    15 ยท 9 months ago
  • โš›๏ธFundamentals
    Blocked on /02/01 , 404 on /react.js
    <Alterion.Dev> ๐Ÿš€:
    I'm currently on <http://localhost:5639/exercise/02/01/problem> , I did in fact properly link the pl...
    • โœ…2
    9 ยท 8 months ago
  • โšกPerformance
    โš›๏ธFundamentals
    Clarification on Calling Components as Interpolated Function Calls
    sethwbarton ๐Ÿš€:
    TL;DR: Is there any reason to prefer the JSX syntax over the interpolation syntax? Is one more perfo...
    • โœ…1
    8 ยท 8 months ago
  • General
    AI Assistant?
    John ๐Ÿš€:
    Kent has mentioned an AI assistant that he's using in VSCode. Is there any detail on what that is an...
    • โœ…2
    2 ยท 8 months ago
  • General
    Script to save playground folder
    larissapissurno ๐Ÿš€:
    Hi all, I personally like to take notes on the playground files, so in order to not lose this notes ...
    • โœ…1
    2 ยท 9 months ago
  • General
    Runninng Learning app on iPad?
    marcus_polonus ๐Ÿš€ ๐ŸŒŒ:
    Hi all, Did anyone managed to setup learning app on iPad? I tried to use codesandbox, but when I am...
    • โœ…1
    1 ยท 9 months ago
  • General
    โš›๏ธFundamentals
    Error boundary good practice
    Lloren ๐Ÿš€:
    I have always wondered if the error boundary is there a limit of error boundary that you can impleme...
    • โœ…1
    1 ยท 9 months ago
  • โš›๏ธFundamentals
    Error on loading deployed version - React Fundamentals
    Lucas Wargha ๐Ÿš€ ๐ŸŒŒ:
    On this link: https://www.epicreact.dev/get-started?module=react-fundamentals%7D if you click on ge...
    • โœ…1
    3 ยท 9 months ago
  • General
    Received this error when running the setup script for React Fundamentals
    ChrisP ๐Ÿš€:
    Hey guys, I am completely blocked at the moment. When I clone and run the setup for react fundamenta...
    • โœ…1
    2 ยท 9 months ago