Submission

Loading "Submission"
๐Ÿจ For this exercise, I want you to read through these instructions and complete things step by step as you read the instructions so you can observe the changes as they come. There aren't a lot of steps, but it's important you understand each one.
I recommend opening the playground in a new tab so you can open the network tab.
๐Ÿ‘จโ€๐Ÿ’ผ Right now, when we submit the form, we get a full page refresh and what we entered ends up in the URL. This is the default behavior of forms. This works well for a search page, but it's certainly not optimal for a form like this one for two reasons:
  1. We don't want to see the data in the URL (like the password) as that can appear in logs, be saved in the browser history, and is visible to anyone looking over our shoulder.
  2. We generally don't want a full-page refresh as that can be jarring to the user and forces the browser to re-evaluate all our client-side JavaScript.
To handle the first problem, let's switch to using POST instead of the default form HTTP method (which is GET). This will send the data in the body of the request instead of in the URL:
<form action="api/onboarding" method="POST"></form>
๐Ÿจ Go ahead and make that change now, then come on back for the rest...
Now, when you submit the form, you'll notice we get an error because our file does not handle the POST request yet.
To fix this, go to and follow the instructions in there to handle non-GET requests. You'll notice we need to switch from using search params to using request.formData() to get the form submission. This is because the body of the request is not a query string, but rather an application/x-www-form-urlencoded request.
๐Ÿจ Ok, now I want you to submit the form again. Make sure you include a photo.
You should notice that it shows the photo's filename rather than showing the file you uploaded. Why is this?
I want you to check the network tab in your dev tools and see what the request looks like because we have a third problem. You'll notice that the Content-Type header is application/x-www-form-urlencoded and the body of the request is a query string. This is the default behavior of forms and it's a fine default for simple forms.
The problem for us is we're trying to upload a file which cannot be reasonably represented by a string in the URL (especially for large files). The file is simply represented by its name, and that is all the server will get which is just not very useful to the server.
We can change that by adding a encType="multipart/form-data" attribute to the form. This will change the Content-Type header to multipart/form-data and the body of the request will be a multipart/form-data request. This is the same type of request that you'd get if you were uploading a file which is what we're doing with the photo.
๐Ÿจ Now, update the form to have the appropriate enctype attribute for file uploads:
<form
	action="api/onboarding"
	method="POST"
	encType="multipart/form-data"
></form>
Great, so now if you check the network tab you'll find that the file is actually uploaded properly.
Now let's get to the full page refresh issue. The only way to solve this is by handling the form submission through JavaScript and preventing the built-in browser behavior. In a real application, you would want to make sure your server can handle those form submissions (for progressive enhancement reasons). But you'll also want to still prevent default to avoid the full-page refresh.
This is where the Remix web framework comes in to handle all that for you. But in this React-focused workshop, we're not going to cover that in detail.
So instead of continuing with our file, we're going to add an onSubmit handler to the form to handle the form submission in JavaScript and prevent the browser's default behavior.
<form
	action="api/onboarding"
	method="POST"
	encType="multipart/form-data"
	onSubmit={event => {
		event.preventDefault()
		// ...
	}}
></form>
๐Ÿจ Go ahead and make that change now, then come on back for the rest...
Now you shouldn't be getting a full-page refresh (and you'll also not be getting the form submission either). So now, we just need to get the form data and log that out. To do that, we'll use the FormData API:
const form = event.currentTarget
const formData = new FormData(form)
// The browser doesn't display form values very well when you console.log(formData)
// so you can do this:
console.log(Object.fromEntries(formData))
// this will create an object out of the properties in the formData so you can
// more easily see what's in there. Keep in mind that formData can have multiple
// values for a single key, so you don't generally want to rely on this method
// for production code.
You can get the form from the submit event via event.currentTarget.
๐Ÿจ Go ahead and make that change now, then come on back for the rest...
Now, when you submit the form, you should see the form data logged out to the console. You can also check the network tab to see that the form submission is not happening so we're not getting an error and there is no refresh.
Great work!

Please set the playground first

Loading "Submission"
Loading "Submission"
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 ยท 4 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 ยท 11 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 ยท 5 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 ยท 9 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