集合
编辑该页面警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 2.1,不再维护。
读这个页面的更新版本Symfob娱乐下载ony 6.3(当前的稳定版本)。
集合
这个约束时使用底层数据是一组(即数组或对象实现可否认的
和ArrayAccess
),但你想以不同的方式验证不同的键的集合。例如,您可以验证电子邮件
主要使用电子邮件
约束和库存
键的集合范围
约束。
这个约束也可以确保存在某些收集钥匙和额外的密钥不存在。
适用于 | 属性或方法 |
选项 | |
类 | 集合 |
验证器 | CollectionValidator |
基本用法
的集合
约束允许你单独验证不同键的集合。下面的例子:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/ / src / Acme / / Author.php BlogBundle /实体名称空间Acme\BlogBundle\实体;类作者{受保护的美元profileData=数组(“personal_email”,“short_bio”,);公共函数setProfileData(美元关键,美元价值){美元这- >profileData [美元关键]=美元价值;}}
来验证,personal_email
元素的profileData
数组属性是一个有效的电子邮件地址,short_bio
元素没有空白,但不超过100个字符长,你会做到以下几点:
1 2 3 4 5 6 7 8 9 10 11 12 13
# src / Acme / BlogBundle /资源/ config / validation.ymlAcme \ BlogBundle \实体\作者:属性:profileData:- - - - - -集合:字段:personal_email:电子邮件short_bio:- - - - - -NotBlank- - - - - -长度:马克斯:One hundred.maxMessage:你的短生物是太长!allowMissingFields:真正的
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17日18 19 20 21日22日23日24日25日26日27
/ / src / Acme / / Author.php BlogBundle /实体名称空间Acme\BlogBundle\实体;使用ob娱乐下载\组件\验证器\约束作为断言;类作者{/ * * *@Assert\收集(={* *字段“personal_email”=@Assert\电子邮件、*“short_bio”= {*@Assert\ NotBlank () *@Assert\长度(* max = 100 * maxMessage =”你的简历太长!”* ) * } * }, * allowMissingFields = true * ) */< /span>受保护的美元profileData=数组(“personal_email”,“short_bio”,);}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
< !- - - - - -- - - - - -src/Acme/BlogBundle/Resources/config/validation.xml -->< /span><类的名字=“Acme \ BlogBundle \实体\作者”><财产的名字=“profileData”><约束的名字=“收集”><选项的名字=“字段”><价值关键=“personal_email”><约束的名字=“电子邮件”/ >< /价值><价值关键=“short_bio”><约束的名字=“NotBlank”/ ><约束的名字=“长度”><选项的名字=“马克斯”>One hundred.< /选项><选项的名字=“maxMessage”>你的简历太长!< /选项>< /约束>< /价值>< /选项><选项的名字=“allowMissingFields”>真正的< /选项>< /约束>< /财产>< /类>
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21日22日23日24
/ / src / Acme / / Author.php BlogBundle /实体名称空间Acme\BlogBundle\实体;使用ob娱乐下载\组件\验证器\映射\ClassMetadata;使用ob娱乐下载\组件\验证器\约束作为断言;类作者{私人美元选项=数组();公共静态函数loadValidatorMetadata(ClassMetadata美元元数据){美元元数据- >addPropertyConstraint (“profileData”,新维护\收集(数组(“字段”= >数组(“personal_email”= >新维护\电子邮件(),“姓”= >数组(新维护\ NotBlank (),新维护\长度(数组(“马克斯”= >One hundred.)))),“allowMissingFields”= >真正的)));}}
存在和缺乏字段
不仅仅在默认情况下,这个约束验证集合中的单个字段是否通过分配约束。事实上,如果集合的任何钥匙丢失或如果有任何识别键的集合,就会抛出验证错误。
如果你想允许键缺席集合或如果你想“额外”键可以在集合,您可以修改allowMissingFields和allowExtraFields分别选择。在上面的例子中,allowMissingFields
选项被设置为true,这意味着如果的personal_email
或short_bio
失踪的元素personalData美元
财产,没有会发生验证错误。
2.1
的要求
和可选
约束是Symfony 2.1。ob娱乐下载
必需和可选字段约束
约束内字段可以用集合要求
或可选
约束来控制是否应该被应用(要求
)或只适用于该领域的存在(可选
)。
例如,如果你想要求personal_email
场的profileData
数组不是空白的,但是是一个有效的电子邮件alternate_email
字段是可选的,但必须是一个有效的电子邮件如果提供,您可以执行以下操作:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
/ / src / Acme / / Author.php BlogBundle /实体名称空间Acme\BlogBundle\实体;使用ob娱乐下载\组件\验证器\约束作为断言;类作者{/ * * *@Assert\收集(={* *字段“personal_email”=@Assert\ \集合要求({@Assert\ NotBlank,@Assert\电子邮件}),*“alternate_email”=@Assert收集\ \可选({@Assert\电子邮件}),*}*)* /受保护的美元profileData=数组(“personal_email”,);}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20
/ / src / Acme / / Author.php BlogBundle /实体名称空间Acme\BlogBundle\实体;使用ob娱乐下载\组件\验证器\映射\ClassMetadata;使用ob娱乐下载\组件\验证器\约束作为断言;类作者{受保护的美元profileData=数组(“personal_email”);公共静态函数loadValidatorMetadata(ClassMetadata美元元数据){美元元数据- >addPropertyConstraint (“profileData”,新维护\收集(数组(“字段”= >数组(“personal_email”= >新维护\ \集合(数组(新维护\ NotBlank (),新维护\电子邮件())),“alternate_email”= >新维护\ \集合可选的(数组(新断言\电子邮件()))))));}}
即使没有allowMissingFields
设置为true,您现在可以省略alternate_email
属性完全从profileData
数组,因为它是可选
。然而,如果personal_email
字段不存在数组中,NotBlank
约束仍将应用(因为它是裹着要求
),你将收到一个约束违反。
选项
allowMissingFields
类型:布尔
默认的:假
如果将此选项设置假
和一个或多个字段字段选项不存在在底层集合,将返回一个验证错误。如果设置为真正的
没关系,如果某些领域“fields_”选项中没有出现在底层的集合。