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