Blank

Валидирует, что значение пустое, а значит равно пустой строке или null:

1
2
3
if ('' !== $value && null !== $value) {
    // валидация будет неудачной
}

Чтобы принудить значение быть строго равно null, см. ограничение IsNull.

Чтобы принудить значение не быть пустым, см. NotBlank. Но будьте осторожны, так как NotBlank не является строгой противоположностью Blank.

Применяется к свойству или методу
Опции
Класс Blank
Валидатор BlankValidator

Базовое применение

Если по какой-то причине вы хотели гарантировать, чтобы свойство firstName класса Author было пустым, вы могли бы сделать следующее:

  • Annotations
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    // src/Entity/Author.php
    namespace App\Entity;
    
    use Symfony\Component\Validator\Constraints as Assert;
    
    class Author
    {
        /**
         * @Assert\Blank()
         */
        protected $firstName;
    }
    
  • YAML
    1
    2
    3
    4
    5
    # config/validator/validation.yaml
    App\Entity\Author:
        properties:
            firstName:
                - Blank: ~
    
  • XML
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    <!-- config/validator/validation.xml -->
    <?xml version="1.0" encoding="UTF-8" ?>
    <constraint-mapping xmlns="http://symfony.com/schema/dic/constraint-mapping"
        xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
        xsi:schemaLocation="http://symfony.com/schema/dic/constraint-mapping http://symfony.com/schema/dic/constraint-mapping/constraint-mapping-1.0.xsd">
    
        <class name="App\Entity\Author">
            <property name="firstName">
                <constraint name="Blank" />
            </property>
        </class>
    </constraint-mapping>
    
  • PHP
     1
     2
     3
     4
     5
     6
     7
     8
     9
    10
    11
    12
    13
    // src/Entity/Author.php
    namespace App\Entity;
    
    use Symfony\Component\Validator\Mapping\ClassMetadata;
    use Symfony\Component\Validator\Constraints as Assert;
    
    class Author
    {
        public static function loadValidatorMetadata(ClassMetadata $metadata)
        {
            $metadata->addPropertyConstraint('firstName', new Assert\Blank());
        }
    }
    

Опции

message

тип: string по умолчанию: Это значение должно быть пустым.

Это сообщение будет отображено, если значение не пустое.

payload

type: mixed default: null

This option can be used to attach arbitrary domain-specific data to a constraint. The configured payload is not used by the Validator component, but its processing is completely up to you.

For example, you may want to use several error levels to present failed constraints differently in the front-end depending on the severity of the error.

Эта документация является переводом официальной документации Symfony и предоставляется по свободной лицензии CC BY-SA 3.0.