yiisoft/form-model

Provides a base for form models and helps to fill, validate and display them.

Maintainers

👁 samdark
👁 vjik

Package info

github.com/yiisoft/form-model

Homepage

Chat

Forum

Wiki

pkg:composer/yiisoft/form-model

Fund package maintenance!

Opencollective

yiisoft

Statistics

Installs: 50 068

Dependents: 13

Suggesters: 0

Stars: 17

Open Issues: 8

1.1.1 2026-03-21 05:47 UTC

Requires

Suggests

None

Provides

None

Conflicts

None

Replaces

None

BSD-3-Clause f89ed3276eadba6d2d997a3d372515cdfd80c20d

formmodel

This package is auto-updated.

Last update: 2026-06-24 21:46:47 UTC


README

👁 Yii

Yii Form Model


👁 Latest Stable Version
👁 Total Downloads
👁 Build status
👁 Code Coverage
👁 Mutation testing badge
👁 static analysis
👁 type-coverage
👁 psalm-level

The package provides a base for form models and helps to fill them with data, validate them and display them.

Requirements

  • PHP 8.1 - 8.5.
  • mbstring PHP extension.

Installation

The package could be installed with Composer:

composer require yiisoft/form-model

General usage

Define a form model:

use Yiisoft\FormModel\Attribute\Safe;
use Yiisoft\FormModel\FormModel;
use Yiisoft\Validator\Rule\Email;
use Yiisoft\Validator\Rule\Length;
use Yiisoft\Validator\Rule\Required;

final class LoginForm extends FormModel
{
 #[Label('Your login')]
 #[Required]
 #[Length(min: 4, max: 40, skipOnEmpty: true)]
 #[Email(skipOnEmpty: true)]
 private ?string $login = null;

 #[Label('Your password')]
 #[Required]
 #[Length(min: 8, skipOnEmpty: true)]
 private ?string $password = null;

 #[Label('Remember me for 1 week')]
 #[Safe]
 private bool $rememberMe = false;
}

Fill it with data and validate using form hydrator:

use Psr\Http\Message\RequestInterface;
use Yiisoft\FormModel\FormHydrator;
use Yiisoft\FormModel\FormModel;

final class AuthController 
{
 public function login(RequestInterface $request, FormHydrator $formHydrator): ResponseInterface
 {
 $formModel = new LoginForm();
 $errors = [];
 if ($formHydrator->populateFromPostAndValidate($formModel, $request)) {
 $errors = $formModel->getValidationResult()->getErrorMessagesIndexedByProperty();
 }
 
 // You can pass $formModel and $errors to the view now.
 }
}

Display it using fields in the view:

use Yiisoft\FormModel\Field;
use Yiisoft\FormModel\FormModel;

echo Field::text($formModel, 'login');
echo Field::password($formModel, 'password');
echo Field::checkbox($formModel, 'rememberMe');

// ...

Documentation

If you need help or have a question, the Yii Forum is a good place for that. You may also check out other Yii Community Resources.

License

The Yii Form Model is free software. It is released under the terms of the BSD License. Please see LICENSE for more information.

Maintained by Yii Software.

Support the project

👁 Open Collective

Follow updates

👁 Official website
👁 Twitter
👁 Telegram
👁 Facebook
👁 Slack