class Forms

Entry point of the Form component.

Use this class to conveniently create new form factories:

use Symfony\Component\Form\Forms;

$formFactory = Forms::createFormFactory();

$form = $formFactory->createBuilder()
    ->add('firstName', 'Symfony\Component\Form\Extension\Core\Type\TextType')
    ->add('lastName', 'Symfony\Component\Form\Extension\Core\Type\TextType')
    ->add('age', 'Symfony\Component\Form\Extension\Core\Type\IntegerType')
    ->add('color', 'Symfony\Component\Form\Extension\Core\Type\ChoiceType', array(
        'choices' => array('Red' => 'r', 'Blue' => 'b'),
    ))
    ->getForm();

You can also add custom extensions to the form factory:

$formFactory = Forms::createFormFactoryBuilder()
    ->addExtension(new AcmeExtension())
    ->getFormFactory();

If you create custom form types or type extensions, it is generally recommended to create your own extensions that lazily load these types and type extensions. In projects where performance does not matter that much, you can also pass them directly to the form factory:

$formFactory = Forms::createFormFactoryBuilder()
    ->addType(new PersonType())
    ->addType(new PhoneNumberType())
    ->addTypeExtension(new FormTypeHelpTextExtension())
    ->getFormFactory();

Support for the Validator component is provided by ValidatorExtension. This extension needs a validator object to function properly:

use Symfony\Component\Validator\Validation;
use Symfony\Component\Form\Extension\Validator\ValidatorExtension;

$validator = Validation::createValidator();
$formFactory = Forms::createFormFactoryBuilder()
    ->addExtension(new ValidatorExtension($validator))
    ->getFormFactory();

Support for the Templating component is provided by TemplatingExtension. This extension needs a PhpEngine object for rendering forms. As second argument you should pass the names of the default themes. Here is an example for using the default layout with "

<

div>" tags:

use Symfony\Component\Form\Extension\Templating\TemplatingExtension;

$formFactory = Forms::createFormFactoryBuilder()
    ->addExtension(new TemplatingExtension($engine, null, array(
        'FrameworkBundle:Form',
    )))
    ->getFormFactory();

The next example shows how to include the "

<

table>" layout:

use Symfony\Component\Form\Extension\Templating\TemplatingExtension;

$formFactory = Forms::createFormFactoryBuilder()
    ->addExtension(new TemplatingExtension($engine, null, array(
        'FrameworkBundle:Form',
        'FrameworkBundle:FormTable',
    )))
    ->getFormFactory();

Methods

createFormFactory()

Creates a form factory with the default configuration.

createFormFactoryBuilder()

Creates a form factory builder with the default configuration.

Details

static FormFactoryInterface createFormFactory()

Creates a form factory with the default configuration.

Return Value

FormFactoryInterface The form factory

static FormFactoryBuilderInterface createFormFactoryBuilder()

Creates a form factory builder with the default configuration.

Return Value

FormFactoryBuilderInterface The form factory builder