Dynamic Rules
You can use the <RCREFormItem />
component the do the component validation.
But form validation is not always static, it may be dynamic and is calculated based on the current state.
This section will describe how to deal with this situation,
Here is an example:
<ES>
{({ $data }) => (
<RCREFormItem
required={true}
rules={[
{
maxLength: $data.max,
message: "The max Length can not over " + $data.max
}
]}
>
{({ valid, errmsg }, { $handleBlur }) => (
<FormItem
label="username"
required={true}
validateStatus={valid ? "success" : "error"}
help={errmsg}
>
<ESInput name="username" onBlur={$handleBlur} />
</FormItem>
)}
</RCREFormItem>
)}
</ES>
In this example, we use the <ES />
component to read the state in the Container and pass it to the validation rules of the FormItem, which forms a dynamic validation.