ArrayControlState
Defined in: hooks/types.ts:255
Состояние массива формы, возвращаемое хуком useFormControl для ArrayNode.
Содержит реактивные данные массива: значения элементов, длину, состояние валидации и флаги взаимодействия.
Example
interface Phone {
type: string;
number: string;
}
interface Props {
control: ArrayNode<Phone>;
}
function PhoneList({ control }: Props) {
const { length, valid } = useFormControl(control);
return (
<div>
{control.map((item, index) => (
<PhoneItem
key={item.id}
control={item}
onRemove={() => control.remove(index)}
/>
))}
{length === 0 && <p>No phones added</p>}
<button onClick={() => control.push({ type: 'mobile', number: '' })}>
Add Phone
</button>
{!valid && <p className="error">Please fix phone errors</p>}
</div>
);
}
See
- useFormControl - хук для получения состояния
- FieldControlState - состояние для полей
Type Parameters
T
T
Тип элемента массива (обычно объект с полями формы)
Properties
dirty
dirty: boolean;
Defined in: hooks/types.ts:345
Флаг изменения.
true когда значение массива отличается от начального.
Example
const { dirty } = useFormControl(itemsArray);
return (
<div>
{dirty && <span>* Unsaved changes</span>}
<button disabled={!dirty}>Save</button>
</div>
);
errors
errors: ValidationError[];
Defined in: hooks/types.ts:309
Массив ошибок валидации уровня массива. Не включает ошибки отдельных элементов.
Example
// Валидатор массива
validators.apply(phonesArray, {
validator: (phones) => phones.length >= 1,
message: 'At least one phone required'
});
// В компоненте
const { errors } = useFormControl(phonesArray);
// errors содержит ошибку "At least one phone required" если массив пуст
invalid
invalid: boolean;
Defined in: hooks/types.ts:321
Флаг невалидности.
true когда есть ошибки в массиве или любом элементе.
length
length: number;
Defined in: hooks/types.ts:284
Количество элементов в массиве. Эквивалентно value.length, но оптимизировано для реактивности.
Example
const { length } = useFormControl(itemsArray);
return (
<div>
<span>Items: {length}</span>
{length >= 10 && <span>Maximum reached</span>}
</div>
);
pending
pending: boolean;
Defined in: hooks/types.ts:290
Флаг асинхронной валидации.
true когда выполняется асинхронный валидатор массива или любого элемента.
touched
touched: boolean;
Defined in: hooks/types.ts:327
Флаг взаимодействия.
true после взаимодействия с любым элементом массива.
valid
valid: boolean;
Defined in: hooks/types.ts:315
Флаг валидности массива и всех его элементов.
true только когда массив и все вложенные элементы валидны.
value
value: T[];
Defined in: hooks/types.ts:266
Массив текущих значений всех элементов.
Example
const { value } = useFormControl(phonesArray);
console.log(value);
// [{ type: 'mobile', number: '+1234567890' }, { type: 'home', number: '+0987654321' }]