Skip to content

Simplified forms in React, with built in validation and submission support

License

Notifications You must be signed in to change notification settings

SpenserJ/react-freeform

Repository files navigation

react-freeform

Build Status codecov npm

The goal of Freeform is to provide an unopinionated framework for building forms, without manually passing values and onChange events. There are only 3 decisions that have been made that limit your freedom, and all of them have workarounds if they impede your project.

  • You must know the default values before the form is rendered
  • You may not change the type of a value after it has been set
    • Changing from an object to a string is usually a sign of data integrity problems
    • <input> forces values to be a string, but if a value was previously a number, Freeform will attempt to typecast it back into one
  • Your form must support an object of values.
    • If you're building a form with a single value, you probably don't need this library
    • If you're building an array of values, you will need to put it in an object first and access it during the submit

Beyond these limitations, Freeform tries to let you write your form however you please. You can build a form that uses 2005-style POST submissions, GraphQL, WebSockets, or anything else you can imagine. Any component's render can be overridden, and Freeform can work with any input field available, often out of the box.

Installation

React Freeform requires React 16.0 or later.

npm install --save react-freeform

Documentation

License

MIT

About

Simplified forms in React, with built in validation and submission support

Topics

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published