Create React Elements

πŸ‘¨β€πŸ’Ό Let's convert this to use React! But don't worry, we won't be doing any JSX just yet... You're going to use raw React APIs here.
In modern applications, you typically get React and React DOM files from a "package registry", like npm where packages we use are (react and react-dom).
A package registry is a centralized repository where developers can publish and share reusable code packages.
To keep things simple for these exercises, we'll import React from slightly different locations:
  • public/react.js (accessed at /react.js)
  • public/react-dom/client.js (accessed at /react-dom/client.js)
These files use a service called esm.sh to provide the React packages.
Don't worry too much about esm.sh for now - it's just helping us load React easily in these exercises.
Here's a simple example of how to use the React createElement API:
import { createElement } from '/react.js'
import { createRoot } from '/react-dom/client.js'

const elementProps = { id: 'element-id', children: 'Hello world!' }
const elementType = 'h1'
const reactElement = createElement(elementType, elementProps)

const root = createRoot(rootElement)
root.render(reactElement)
πŸ¦‰ As a reminder, in a typical application, your import will be something like
import { createRoot } from 'react-dom/client'
With that, a build tool or importmap will handle resolving that to the correct path.
The "props" in elementProps above is short for "properties". Props are a key concept in React - they're the way we pass data into our elements. You can think of the element type as a blueprint for the kind of React component to create, and the props are the inputs that customize that element.
children is a special prop in React. It represents the content inside an element. You have a few ways to specify children:
  1. As a prop (like in the first example above)
  2. As multiple arguments to createElement
  3. As an array
Here's an example showing the last two methods:
const elementProps = { id: 'element-id' }
const elementType = 'h1'

// Method 2: Multiple arguments
const reactElement1 = createElement(
	elementType,
	elementProps,
	'Hello',
	' ',
	'world!',
)

// Method 3: Array of children
const children = ['Hello', ' ', 'world!']
const reactElement2 = createElement(elementType, elementProps, children)

createRoot(rootElement).render(reactElement1) // or reactElement2
Alright! Let's put this into practice!
πŸ’° Tip: Use console.log(reactElement) to see what your created element looks like. You might find the structure interesting!

Please set the playground first

Loading "Create React Elements"
Loading "Create React Elements"
Login to get access to the exclusive discord channel.
  • 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
    61 Β· a month ago
  • 🎣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
    1 Β· 3 months ago
  • General
    Full app architecture in Epic React?
    Sorix πŸš€:
    The Epic React course is broken into small focused modules, but is there a final project that shows ...
    • βœ…1
    1 Β· 2 months 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 Β· 3 months 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 Β· 10 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 Β· 5 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 Β· 5 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 Β· 6 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 Β· 7 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 Β· 7 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 Β· 7 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 Β· 7 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 Β· 8 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 Β· 8 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 Β· a year 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 Β· 8 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 Β· 9 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 Β· 9 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 Β· 9 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 Β· 9 months ago
  • General
    Problem with playground
    Xrayoptions πŸš€:
    Problem section doesn't show <@105755735731781632> how to fix it ?
    • βœ…1
    9 Β· 9 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 Β· 10 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 Β· 10 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 Β· a year 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 Β· a year 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 Β· a year ago