Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/fabian-hiller/modular-forms

The modular and type-safe form library for SolidJS, Qwik and Preact
https://github.com/fabian-hiller/modular-forms

bundle-size form form-validation forms performance preact qwik signals solid type-safe typescript validation

Last synced: 7 days ago
JSON representation

The modular and type-safe form library for SolidJS, Qwik and Preact

Awesome Lists containing this project

README

        

# Modular Forms

Modular Forms is a JavaScript library built on [SolidJS](https://www.solidjs.com/), [Qwik](https://qwik.builder.io/), [Preact](https://preactjs.com/) and [React](https://react.dev/) to validate and handle various types of forms. It is type-safe, fast by default and the bundle size is small due to a modular design. Try it out in our [playground](https://modularforms.dev/playground)!

## ✨ Highlights

- Small bundle size starting at 3 KB
- It's fast – DOM updates are fine-grained
- Type safety with autocompletion in editor
- Validate everything from emails to files
- Minimal, readable and well thought out API
- Progressively enhanced forms with actions
- Modular design – only use what you need
- No dependencies – except for the framework
- It's headless – you define the visual
- Supports all native HTML form fields

## 🏔 Mission

The mission of Modular Forms is to gather the latest available experience and knowledge to provide the best possible form library for JavaScript frameworks. We pay special attention to type safety, bundle size, performance and input validation. You can expect that every decision we make during development is well thought out and always takes these main features into account.

## 🪐 Vision

At the time of the initial development of Modular Forms, there was no form library with comparable type safety, bundle size and performance. However, many of the ideas came from previous open source projects and only the development of the last few years has made a form library in this way possible. The vision of Modular Forms is to shape the future of the web together and to share our knowledge and experience with the open source community.

## 🙌🏼 Credits

When creating Modular Forms, I took inspiration from [React Hook Form](https://react-hook-form.com/) and [Formik](https://formik.org/). I also want to thank [Ryan Carniato](https://twitter.com/RyanCarniato) for his inspiring streams with exclusive and deep insights into different technologies. Furthermore, I would like to thank [David Di Biase](https://twitter.com/davedbase), [Miško Hevery](https://twitter.com/mhevery) and [Manu Martínez-Almeida](https://twitter.com/manucorporat) for the support I received during the initial development.

## ✏️ Feedback

Find a bug or have an idea how to improve the library? Please fill out an [issue](https://github.com/fabian-hiller/modular-forms/issues/new). Together we can make the library even better!

## 🔑 License

This project is available free of charge and licensed under the [MIT License](https://github.com/fabian-hiller/modular-forms/tree/main/LICENSE.md).