Skip to content

How to only accept images in an input file field

When adding a file field to a form, you might want to limit the selector to images

Of course you could add a server-side filter, but also having a client-side filter is a great UX for your users - no time wasted and no resources wasted to send a file to you and get back with an error.

You can do so by using the accept attribute, and specifying the MIME type of the files you accept.

image/* should catch all images.

<input type="file" name="myImage" accept="image/*" />

If you want to only allow some specific file types, list them:

<input type="file" name="myImage" accept="image/x-png,image/gif,image/jpeg" />

You can check the browser support for this attribute here: https://caniuse.com/#feat=input-file-accept


I wrote 21 books to help you become a better developer:

  • HTML Handbook
  • Next.js Pages Router Handbook
  • Alpine.js Handbook
  • HTMX Handbook
  • TypeScript Handbook
  • React Handbook
  • SQL Handbook
  • Git Cheat Sheet
  • Laravel Handbook
  • Express Handbook
  • Swift Handbook
  • Go Handbook
  • PHP Handbook
  • Python Handbook
  • Linux Commands Handbook
  • C Handbook
  • JavaScript Handbook
  • Svelte Handbook
  • CSS Handbook
  • Node.js Handbook
  • Vue Handbook
...download them all now!

Related posts that talk about platform: