🎁 The Js-Craft Guide to React is now available with a 30% off discount!

Differences between requestSubmit() and submit() in HTML forms

The most used way to programmatically submit an HTML form with Javascript is the submit method:

<form>   
  <input required name="email" id="email" type="email" placeholder="Email here ...">
  <input type="submit" class="submit-btn" value="Use submit()" />
</form>
const form = document.forms[0]
document.querySelector('.submit-btn')
  .addEventListener('click', () => form.submit()
    form.submit())

However, it has (at least) 2 unexpected behaviors:

  1. submit will bypass the validation of the form. This means that the above form will be subbitment even if we have the required attribute set on the email input and that input is empty.
    // submit() will not take into account the required attr
    <input required name="email" id="email" type="email" >
  2. if we a add addEventListener('submit') to the form submit will also bypass it. For example:
    form.addEventListener('submit', e => {
    // this code will not be called when using submit()
    e.preventDefault()
    alert('Code after preventDefault called')
    })

Now with a full browser support, requestSubmit method aims to provide an more predictable behaivour to our form submisons. The requestSubmit() will take into account both the native form validation and it alows interceptions with addEventListener('submit').

form.addEventListener('submit', e => {
  // this will be called only 
  // when using requestSubmit()
  e.preventDefault()
  alert('Code after preventDefault called')
})

document.querySelector('.submit-btn')
  .addEventListener('click', () => form.submit()
    form.submit())

// requestSubmit() will first check for form validation
document.querySelector('.requestSubmit-btn')
  .addEventListener('click', () => form.requestSubmit())

Checkout a working codepen here.

And speaking of submitting forms I've also made this example of how to use the FormData Api and append extra data to it and what errors you can get.

10 Javascript AI projects with Langchain & React

Not sure what to build? Dive in with these Javascript AI projects! Learn how to build LLM powered apps using Langchain.js and React! Connect your apps to LLMs such as OpenAI, create agents, use vector databases, or setup AI context.

10 Javascript AI projects with Langchain & React

Not sure what to build? Dive in with these Javascript AI projects! Learn how to build LLM powered apps using Langchain.js and React! Connect your apps to LLMs such as OpenAI, create agents, use vector databases, or setup AI context.


Leave a Reply

Your email address will not be published. Required fields are marked *

📘 The Guide to React Home Screencasts Best of Newsletter Search X

📘 - 10 Javascript AI projects with React and LangChain

Hi friend! Before you go, just wanted to let you know about the 10 Javascript AI projects ideas with React and LangChain FREE ebook.

One of the best ways to learn is by doing the work. Choose from these 10 project ideas and start working on topics such as:

  • How does LangChain work
  • Connecting to OpenAI LLM
  • Create AI Agents
  • Simple and Sequential Chains
  • Adding Memory (Chat Context)
  • Prompt Templates
  • Using OutputParsers and Tools for Agents
  • Work with Documents and more...

Keep building and see the new capabilities LLM models can add to your React app! Get all projects as an ebook right to your inbox!

X