Forms 101: Receiving the form data

Hey, make sure you join my 🥾 ⛺ BOOTCAMP waiting list, next cohort in March/April/May 2025

Let’s now handle receiving the form data.

The simplest way I know to test this is by creating a simple Astro site with server-side rendering enabled.

Create an empty Astro site using

npm create astro@latest

Now go in the folder and install the Node.js adapter with

npx astro add node

This changed the astro.config.mjs configuration to:

import { defineConfig } from 'astro/config'

import node from '@astrojs/node'

// https://astro.build/config
export default defineConfig({
  output: 'server',
  adapter: node({
    mode: 'standalone',
  }),
})

Run npm run dev to start the Astro site.

Now go to src/pages/index.astro and add the form to the body:

<html lang='en'>
  <head>
    <meta charset='utf-8' />
    <link rel='icon' type='image/svg+xml' href='/favicon.svg' />
    <meta name='viewport' content='width=device-width' />
    <meta name='generator' content={Astro.generator} />
    <title>Astro</title>
  </head>
  <body>
    <form method='post'>
      <input type='text' name='city' />
    </form>
  </body>
</html>

This should be what you see in the browser:

To handle the server-side data, now we add some JavaScript code to the frontmatter of the component, which is something Astro-specific and basically where code runs server-side when we hit the page endpoint /:

---

---

<html lang='en'>
  ...
</html>

Inside it, we can handle a POST request using:

---
if (Astro.request.method === 'POST') {

}
---

<html lang='en'>
  ...
</html>

and when we do so, we can now access the form data calling the formData() method on the Request object, which is available in this case through Astro.request:

---
if (Astro.request.method === 'POST') {
  const data = await Astro.request.formData()
}
---

<html lang='en'>
  ...
</html>

(we have to use await because calling formData() returns a promise).

This is all standard Web APIs: Request, FormData.

Now we can access individual data using data.get():

---
if (Astro.request.method === 'POST') {
  const data = await Astro.request.formData()
  const city = data.get('city')
  console.log(city)
}
---

<html lang='en'>
  ...
</html>

FormData provides many other methods, see the full list on MDN.

Try it! You should see the data entered in the input field printed to the terminal running npm run dev.

Lessons in this unit:

0: Introduction
1: Creating a form
2: Submitting a form
3: ▶︎ Receiving the form data
4: Form validation
5: More tags useful in forms