[042] Symfony4 表单入门 Part02

Web 应用中, 对表单的验证是与生俱来的需求. Symfony 在这方面提供了非常好的支持. 简单易用.

关于表单验证这里, 和 Zend Framework 3 比起来, Symfony4 提供了更容易的实现方式. 通常在 Zend Framework 3 中, 表单验证工作通常都放在 Form 的创建阶段, 这方面和 Symfony4 有些区别, Symfony4 把验证工作可以直接对应到实体类声明中. 这样对简单表单应用就非常的容易和直观, 当然 Symfony4 也支持在 Form 创建的时候传递一个合约声明来约束验证表单输入的内容.

还是以用注册为例, 来实际使用了一下便捷的表单验证功能. 这里顺便说到 Symfony/Validator 非常的强大. 表单验证这里只是使用了小部分基础的功能.

我们对用户注册涉及到的实体类的属性 用户名 name, 注册邮箱 email, 用户密码 passwd 分别进行约束. 修改 src/Entity/User.php 代码, 看起来像这样:

再稍微修改一下表单创建部分代码:

public function signUp(Request $request)
{
        $user = new User();

        $formBuilder = $this->createFormBuilder($user);
        $formBuilder->add('name', TextType::class, ['empty_data' => '']);
        $formBuilder->add('email', EmailType::class, ['empty_data' => '']);
        $formBuilder->add('passwd', PasswordType::class, ['empty_data' => '']);
        $formBuilder->add('save', SubmitType::class);
        $form = $formBuilder->getForm();
        //... other code
}

经过简单的设置, 表单就变的非常的安全了. symfony/validator 组件提供的内置验证器非常的多. 具体可以参考文档: Symfony Validation

看一下验证的效果截图:

[042] Symfony4 表单入门 Part02_第1张图片
什么都不填写时提交后表单效果
[042] Symfony4 表单入门 Part02_第2张图片
输入非法信息提交后表单效果

非常的简单, 方便.

你可能感兴趣的:([042] Symfony4 表单入门 Part02)