EnumType领域
编辑该页面警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 6.0,不再维护。
读这个页面的更新版本Symfob娱乐下载ony 6.3(当前的稳定版本)。
EnumType领域
多用字段用来允许用户“选择”中定义的一个或多个选项PHP枚举。它扩展了ChoiceType场和定义相同的选项。
呈现为 | 可以各种标记(见下文) |
默认的无效信息 | 选择的选择是无效的。 |
遗留无效的信息 | {{value}}的值是无效的。 |
父类型 | ChoiceType |
类 | EnumType |
提示
选项的完整列表和继承了这种类型定义在你的应用可以运行这个命令:
1 2
#替换“FooType”的表单类型的类名美元php bin /控制台调试:FooType形式
示例使用
在使用这个领域之前,你需要有一些PHP定义枚举(简称“枚举”)在您的应用程序。这个枚举类型的必须是“支持枚举”,其中每个关键字定义标量值如一个字符串:
1 2 3 4 5 6 7 8 9
/ / src / Config / TextAlign.php名称空间应用程序\配置;字符串枚举TextAlign: {情况下离开了=“左对齐”;情况下中心=的中心对齐;情况下正确的=“右对齐”;}
而不是使用枚举的值选择
选项时,EnumType
只需要定义类
选项指向枚举:
1 2 3 4 5
使用应用程序\配置\TextAlign;使用ob娱乐下载\组件\形式\扩展\核心\类型\EnumType;/ /……美元构建器- >add (“对齐”,EnumType::类,“类”= > TextAlign::类);
这将显示一个<选择>
标签中定义的三种可能的值TextAlign
枚举。使用扩大和多个选项来显示这些值< input type = "复选框" >
或< input type = "电台" >
。
标签中显示<选项>
的元素<选择>
是枚举名称。PHP定义了一些严格的规则,这些名称(例如,他们不能包含点或空格)。如果你需要更大的灵活性对于这些标签,使用choice_label
选择和定义一个函数,它返回自定义标签:
1 2 3 4 5 6 7 8
- >add (“textAlign”,EnumType::类,“类”= > TextAlign::类,“choice_label”= > fn (美元选择)= >匹配(美元选择){TextAlign::左= >“text_align.left.label”,TextAlign::中心= >“text_align.center.label”,TextAlign::正确的= >“text_align.right.label”}));
继承的选项
这些选项的继承ChoiceType:
error_bubbling
类型:布尔
默认的:假
除非表单复合
如果真正的
,这个领域的任何错误将被传递到父字段或形式。例如,如果设置为真正的
正常,任何错误的字段将被附加到的主要形式,而不是特定的字段。
error_mapping
类型:数组
默认的:[]
这个选项允许您修改验证错误的目标。
想象你有一个自定义的命名方法matchingCityAndZipCode ()
验证城市和邮编是否匹配。不幸的是,没有matchingCityAndZipCode
在表单字段,所以Symfony所能做的一切是显示错误的形式。ob娱乐下载
自定义错误映射,你可以做得更好:误差映射到城市字段以便它上面显示:
1 2 3 4 5 6 7 8
公共函数configureOptions(OptionsResolver美元解析器){美元解析器- >setDefaults ([“error_mapping”= > [“matchingCityAndZipCode”= >“城市”、]]);}
这里的规则是左边和右边的映射:
- 左侧包含属性的路径;
- 如果违反上生成一个类的属性或方法,它的路径
propertyName
; - 如果违反上生成一个条目的
数组
或ArrayAccess
对象,属性路径(indexName)
; - 您可以构建嵌套属性路径通过连接,分离属性点。例如:
地址[工作].matchingCityAndZipCode
; - 右侧包含表单中字段的名称。
默认情况下,没有任何属性映射错误将泡沫到父窗体。您可以使用点(。
)左边错误的所有地图上未标明的属性映射到一个特定的领域。例如,所有这些错误的地图城市
字段中,使用:
1 2 3 4 5
美元解析器- >setDefaults ([“error_mapping”= > [“。”= >“城市”、]]);
group_by
类型:字符串
或可调用的
或PropertyPath默认的:零
你可以组<选项>
的元素<选择>
成< optgroup >
通过一个多维数组选择
。看到分组选项部分。
的group_by
选择另一种方法是集团的选择,给你更多的灵活性。
让我们添加一些案件TextAlign
枚举:
1 2 3 4 5 6 7 8 9 10 11 12 13
/ / src / Config / TextAlign.php名称空间应用程序\配置;字符串枚举TextAlign: {情况下UpperLeft =“左对齐”;情况下LowerLeft =较低的左对齐的;情况下中心=的中心对齐;情况下UpperRight =“上右对齐”;情况下LowerRight =“低右对齐”;}
我们现在可以选择的枚举值:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18
使用应用程序\配置\TextAlign;使用ob娱乐下载\组件\形式\扩展\核心\类型\EnumType;/ /……美元构建器- >add (“对齐”,EnumType::类,“类”= > TextAlign::类,“group_by”= >函数(TextAlign美元选择,int美元关键、字符串美元价值):哦?字符串{如果(str_starts_with (美元价值,“上”)){返回“上”;}如果(str_starts_with (美元价值,“低”)){返回“低”;}返回“其他”;}));
这个回调将集团选择在3类:上
,较低的
和其他
。
如果你返回零
,选择不会分组。
占位符
类型:字符串
或布尔
这个选项决定是否一个特殊的“空”选项(如。“选择一个选项”)将出现在顶部的选择小部件。此选项仅适用于如果多个
选项设置为false。
添加一个空值与“选择一个选项”:
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\扩展\核心\类型\ChoiceType;/ /……美元构建器- >add (“州”,ChoiceType::类,“占位符”= >选择一个选项的]);
保证没有“空”的价值选择是显示:
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\扩展\核心\类型\ChoiceType;/ /……美元构建器- >add (“州”,ChoiceType::类,“占位符”= >假]);
如果你离开占位符
选项设置,然后一个空白(无文本)选项将自动添加当且仅当要求
选项是错误的:
1 2 3 4 5 6 7
使用ob娱乐下载\组件\形式\扩展\核心\类型\ChoiceType;/ /……/ /一个空白(没有文本)选项将被添加美元构建器- >add (“州”,ChoiceType::类,“要求”= >假]);
preferred_choices
类型:数组
,可调用的
,字符串
或PropertyPath默认的:[]
这个选项允许您显示特定的选择列表的顶部与视觉之间的分隔符和选项的完整列表。如果你有一种语言,你可以列出最受欢迎的顶部,如博克和海盗:
1 2 3 4 5 6 7 8 9 10 11 12
使用ob娱乐下载\组件\形式\扩展\核心\类型\ChoiceType;/ /……美元构建器- >add (“语言”,ChoiceType::类,“选择”= > [“英语”= >“en”,“西班牙”= >“西文”,“博克”= >“布偶”,“海盗”= >“加勒比海盗”),“preferred_choices”= > [“布偶”,“加勒比海盗”)));
这个选项也可以一个回调函数给你更多的灵活性。这可能是特别有用如果你值对象:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
使用ob娱乐下载\组件\形式\扩展\核心\类型\ChoiceType;/ /……美元构建器- >add (“publishAt”,ChoiceType::类,“选择”= > [“现在”= >新\ DateTime (“现在”),“明天”= >新\ DateTime (“+ 1天”),“1周”= >新\ DateTime (“+ 1周”),“一个月”= >新\ DateTime (“+ 1月”),),“preferred_choices”= >函数(美元选择,美元关键,美元价值){/ /选择选项3天内返回美元选择< =新\ DateTime (+ 3天的);}));
这将“喜欢”“现在”和“明天”的选择只有:
最后,如果你的价值观是对象,您还可以指定属性路径字符串对象,它将返回true或false。
首选的选择呈现时才有其意义选择
元素(即。扩大
假)。优先选择和正常的选择是由一组分离视觉虚线(即。- - - - - - - - - - - - - - - - - - -
)。这可以定制在呈现字段:
1
{{form_widget(形式。publishAt,{“分离器”:“= = = = = '})}}
1 2 3
< ?=美元视图(“形式”]- >小部件(美元形式(“publishAt”]、[“分隔符”= >“= = = = =”,)? >
提示
定义一个自定义类型时,您应该使用ChoiceList类辅助:
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\ChoiceList\ChoiceList;/ /……美元构建器- >add (“选择”,ChoiceType::类,“preferred_choices”= > ChoiceList::优先(美元这,“taggedAsFavorite”)));
attr
类型:数组
默认的:[]
如果你想添加额外的属性可以使用HTML字段表示attr
选择。这是一个与HTML属性关联数组的键。这可能是有用的,当你需要设置一个自定义类部件:
1 2 3
美元构建器- >add (“身体”,TextareaType::类,“attr”= > [“类”= >“tinymce”)));
另请参阅
使用row_attr
选择如果你想将这些属性添加到表单类型行元素。
数据
类型:混合
默认的:默认字段的底层结构。
当你创建一个表单,最初显示每个字段的值对应的表单的域数据的属性(例如,如果您将对象绑定到表单)。如果你想覆盖这个表单或单个字段的初始值,你可以设置它在数据选项:
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\扩展\核心\类型\HiddenType;/ /……美元构建器- >add (“令牌”,HiddenType::类,“数据”= >“六边形abcdef”]);
谨慎
的数据
选项总是覆盖的值从域数据(对象)呈现。这意味着对象的值也覆盖当表单编辑已经持久化的对象,使其在表单提交时失去保存价值。
empty_data
类型:混合
这个选项决定了价值领域返回当提交的值为空(或失踪)。它没有设置一个初始值时如果没有提供一个视图的形式呈现。
这意味着它可以帮助您处理表单提交空白的领域。例如,如果你想要的的名字
字段被显式地设置John Doe
当选择没有价值,你可以这样做:
1 2 3 4
美元构建器- >add (“名字”,零,(“要求”= >假,“empty_data”= >“John Doe”]);
这仍将呈现一个空的文本框,但在提交John Doe
值将被设置。使用数据
或占位符
选项来显示这个初始值呈现形式。
如果一种复合,可以设置empty_data
作为数组、对象或关闭。看到如何配置空数据形式类文章关于这些选项的更多细节。
请注意
如果你想设置empty_data
选择整个表格类,看到如何配置空数据形式类篇文章。
谨慎
表单数据变形金刚仍将被应用到吗empty_data
价值。这意味着将把一个空的string零
。使用自定义数据变压器如果你明确想返回一个空字符串。
帮助
类型:字符串
或TranslatableMessage
默认的:零
允许您定义一个表单字段的帮助信息,默认情况下是呈现以下字段:
1 2 3 4 5 6 7 8 9 10 11 12 13
使用ob娱乐下载\组件\翻译\TranslatableMessage;美元构建器- >add (“zipCode”,零,(“帮助”= >你的信用卡的邮政编码\ ' s帐单地址。,)/ /……- >add (“状态”,零,(“帮助”= >新TranslatableMessage (“order.status”,(“% order_id %”= >美元订单- >getId ()),“存储”)));
help_attr
类型:数组
默认的:[]
设置元素的HTML属性用于显示帮助信息的表单字段。它的值是一个关联数组与HTML属性名称作为键。这些属性也可以在模板设置:
1 2 3
{{form_help (form.name,“你的名字”,{help_attr:{‘类’:‘CUSTOM_LABEL_CLASS}})}}
标签
类型:字符串
或TranslatableMessage
默认的:标签是“猜”字段名称
设置标签时,将使用渲染。设置为假
将抑制标签:
1 2 3 4 5 6 7 8
使用ob娱乐下载\组件\翻译\TranslatableMessage;美元构建器- >add (“zipCode”,零,(“标签”= >“邮政编码”,/ /可选地,您可以使用TranslatableMessage对象作为标签的内容“标签”= >新TranslatableMessage (“address.zipCode”,(%的国家%的= >美元国家),“地址”),)
标签也可以在模板设置:
1
{{了form_label (form.name '你的名字')}}
1 2 3 4
回声美元视图(“形式”]- >标签(美元形式(“名字”),“你的名字”);
label_attr
类型:数组
默认的:[]
集的HTML属性<标识>
元素,它将使用时呈现字段的标签。这是一个关联数组与HTML属性作为一个关键。这个属性也可以直接设置在模板:
1 2 3
{{了form_label (form.name,“你的名字”,{label_attr:{‘类’:‘CUSTOM_LABEL_CLASS}})}}
1 2 3 4 5
回声美元视图(“形式”]- >标签(美元形式(“名字”),“你的名字”,(“label_attr”= > [“类”= >“CUSTOM_LABEL_CLASS”]]);
label_format
类型:字符串
默认的:零
配置字段的字符串作为标签,以防标签
选择是没有设置,这是有用的在使用关键字翻译的消息。
如果你使用关键字翻译信息标签,你经常有多个关键字信息相同的标签(如。profile_address_street
,invoice_address_street
)。这是因为每个“路径”的标签是建立一个字段。为了避免重复的关键字信息,您可以配置标签格式一个静态值,如:
1 2 3 4 5 6 7 8
/ /……美元profileFormBuilder- >add (“地址”,AddressType::类,“label_format”= >“form.address. %名称%”]);美元invoiceFormBuilder- >add (“发票”,AddressType::类,“label_format”= >“form.address. %名称%”]);
这个选项是遗传的子类型。上面的代码的标签街
两种形式将使用领域form.address.street
关键字信息。
两个变量标签格式是可用的:
-
% id %
-
字段的惟一标识符,包括完整的路径字段和字段名(如。
profile_address_street
); -
%的名字%
-
字段名(如。
街
)。
默认值(零
)的结果“人性化”版本的字段名。
请注意
的label_format
选择是评估形式的主题。如果你一定要更新您的模板定制的形式主题。
要求
类型:布尔
默认的:真正的
如果这是真的,一个HTML5必需属性将会呈现。相应的标签
还将呈现的要求
类。
这是肤浅的和独立的验证。在最好的情况下,如果你让Symfony猜ob娱乐下载你的字段类型,那么这个选项的值将从你的猜测验证信息。
请注意
所需的选择也会影响每个字段是空的数据如何处理。更多细节,请参阅empty_data选择。