React Advanced Form
  • Introduction
  • General
    • Comparison
      • Compared to Formik
      • Compared to Final form
    • Migration guides
      • 1.4.x → 1.5.x
    • FAQ
  • Getting started
    • Installation
    • Creating fields
    • Creating form
    • Validation rules
    • Validation messages
    • Applying validation
    • Handle submit
  • Architecture
    • Argument properties
    • Referencing
    • Field lifecycle
    • Controlled fields
    • Reactive props
  • Validation
    • Getting started
    • Validation schema
      • Rule definition
      • Reactive rule
    • Validation messages
  • High-order components
    • createField
      • Options
      • Field presets
      • Exposed props
  • Components
    • FormProvider
    • Form
      • Props
        • innerRef
        • initialValues
        • action
        • rules
        • messages
      • Methods
        • setValues()
        • setErrors()
        • reset()
        • validate()
        • serialize()
        • submit()
      • Callbacks
        • onFirstChange
        • onReset
        • onInvalid
        • onSerialize
        • onSubmitStart
        • onSubmitted
        • onSubmitFailed
        • onSubmitEnd
    • Field.Group
    • Field
      • Props
        • rule
        • asyncRule
        • skip
      • Callbacks
        • onFocus
        • onChange
        • onBlur
  • Recipes
    • Generating a form
    • Utilizing functions
  • Developers
    • Contributing
Powered by GitBook
On this page
  • Specification
  • Definition
  • Parameters
  • Example
  1. Components
  2. Field
  3. Props

asyncRule

PreviousruleNextskip

Last updated 6 years ago

Specification

Asynchronous rule of the field applied as the top priority validation after its sibling resolves. Executed on field blur.

  • asyncRule is designed for on blur asynchronous validation of the fields.

  • asyncRule is designed for precise unique field validation.

  • asyncRule must always return the specified AsyncRulePayload Object.

  • asyncRule will not be called if it has been previously resolved and the value of the field has not changed.

Definition

type AsyncRule = (params) => AsyncRulePayload
type AsyncRulePayload = {
  valid: boolean,
  extra?: {
    [exraKey: string]: any
  }
}

Parameters

Parameter name

Type

Description

value

any

The current value of the field.

fieldProps

Object

Props of the current field.

fields

Object

Map of all fields.

form

Object

A reference to the current Form

Example

import React from 'react'
import { Form } from 'react-advanced-form'
import { Input } from 'react-advanced-form-addons'

export default class Example extends React.Component {
  validateUsername = ({ value, fieldProps, fields, form }) => {
    return fetch('https://check.if/user/exists', {
      method: 'POST',
      body: JSON.stringify(value),
    })
    .then(res => res.json())
    .then((res) => {
      const { statusCode } = res

      return {
        valid: (statusCode === 'SUCCESS')
      }
    })
  }

  render() {
    return (
      <Form>
        <Input
          name="username"
          asyncRule={this.validateUsername} />
      </Form>
    );
  }
}
Field.props.rule