react-form-with-constraints
Simple form validation for React
Installation: npm install react-form-with-constraints
CDN: https://unpkg.com/react-form-with-constraints/dist/
Introduction: what is HTML5 form validation?
The required HTML5 attribute specifies that the user must fill in a value, type="email" checks that the entered text looks like an email address.
What react-form-with-constraints brings
- Minimal API and footprint
- Control HTML5 error messages:
<FieldFeedback when="valueMissing">My custom error message</FieldFeedback>
- Custom constraints:
<FieldFeedback when={value => ...}>
- Warnings and infos:
<FieldFeedback ... warning>
,<FieldFeedback ... info>
- Async validation
- No dependency beside React (no Redux, MobX...)
- No special component like
<TextField>
, just plain old<input>
or whatever you like - Re-render only what's necessary
- Support for React Native with npm package
react-form-with-constraints-native
- Easily extendable
- ...
Examples
-
CodePen basic example: https://codepen.io/tkrotoff/pen/BRGdqL
-
CodeSandbox Bootstrap 4 example: https://codesandbox.io/s/qk0zro1qm4
-
CodeSandbox WizardForm example: https://codesandbox.io/s/my0ojyzq6p
-
CodeSandbox SignUp example: https://codesandbox.io/s/62qwozvm0k
-
CodeSandbox ClubMembers example: https://codesandbox.io/s/q8364yn60j
-
React Native example:
iOS Android
How it works
The API works the same way as React Router v4:
It is also inspired by AngularJS ngMessages.
If you had to implement validation yourself, you would end up with a global object that tracks errors for each field.
react-form-with-constraints works similarly.
It uses React context to share the FieldsStore
object across FieldFeedbacks
and FieldFeedback
.
API
The API reads like this: "for field when constraint violation display feedback", example:
for field "password"
when constraint violation "valueMissing" display "the HTML5 error message (*)"
when constraint violation "patternMismatch" display "Should be at least 5 characters long"
Async support works as follow:
Trigger validation:
-
for: string
=> reference to aname
attribute (e.g<input name="username">
), should be unique to the current formstop?: 'first' | 'first-error' | 'first-warning' | 'first-info' | 'no'
=>
when to stop renderingFieldFeedback
s, by default stops at the first error encountered (FieldFeedback
s order matters)
Note: you can place
FieldFeedbacks
anywhere, have as many as you want for the samefield
, nest them, mix them withFieldFeedback
... Dirty example: -
when?
:ValidityState
as a string => HTML5 constraint violation name'*'
=> matches any HTML5 constraint violation'valid'
=> displays the feedback only if the field is valid(value: string) => boolean
=> custom constraint
error?: boolean
=> treats the feedback as an error (default)warning?: boolean
=> treats the feedback as a warninginfo?: boolean
=> treats the feedback as an infochildren
=> what to display when the constraint matches; if missing, displays the HTML5 error message if any
-
Async<T>
=> Async version ofFieldFeedback
, similar API as react-promisepromise: (value: string) => Promise<T>
=> a promise you want to wait forpending?: React.ReactNode
=> runs when promise is pendingthen?: (value: T) => React.ReactNode
=> runs when promise is resolvedcatch?: (reason: any) => React.ReactNode
=> runs when promise is rejected
-
-
validateFields(...inputsOrNames: Array<Input | string>): Promise<Field[]>
=>
Should be called when afield
changes, will re-render the properFieldFeedback
s (and update the internalFieldsStore
).
Without arguments, all fields ($('[name]')
) are validated. -
validateForm(): Promise<Field[]>
=>
Should be called before to submit theform
. Validates only all non-dirty fields (won't re-validate fields that have been already validated withvalidateFields()
),
If you want to force re-validate all fields, usevalidateFields()
without arguments. -
isValid(): boolean
=> should be called aftervalidateForm()
orvalidateFields()
, tells if the known fields are valid (thanks to internalFieldsStore
) -
reset(): Promise
=> resets internalFieldsStore
and re-render allFieldFeedback
s -
Field
=>
-