选择字段类型
编辑该页面警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 2.5,不再维护。
读这个页面的更新版本Symfob娱乐下载ony 6.3(当前的稳定版本)。
选择字段类型
多用字段用来允许用户“选择”一个或多个选项。它可以呈现为一个选择
标签、单选按钮或复选框。
使用这个字段,您必须指定要么的choice_list
或选择
选择。
呈现为 | 可以各种标记(见下文) |
选项 | |
覆盖选项 | |
继承的选项 | |
父类型 | 形式 |
类 | ChoiceType |
示例使用
使用这一领域的最简单的方法是直接通过指定的选择选择
选择。数组的键成为价值实际上是设置你的潜在对象(如。米
),而价值是用户看到的形式(如。男性
)。
1 2 3 4
美元构建器- >add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”),“要求”= >假));
通过设置多个
真的,你可以允许用户选择多个值。小部件将会呈现多个选择
标签或一系列复选框根据扩大
选择:
1 2 3 4 5 6 7 8
美元构建器- >add (“可用性”,“选择”,数组(“选择”= >数组(“早晨”= >“早晨”,“下午”= >“下午”,“晚上”= >“晚上”),“多”= >真正的));
您还可以使用choice_list
选项,该选项需要一个对象,可以指定选择为您的小部件。
选择标签,复选框或单选按钮
这一领域可能呈现为不同的HTML字段之一,根据扩大
和多个
选项:
元素类型 | 扩大 | 多个 |
---|---|---|
选择标记 | 假 |
假 |
选择标签(多个 属性) |
假 |
真正的 |
单选按钮 | 真正的 |
假 |
复选框 | 真正的 |
真正的 |
场的选择
选择
类型:数组
默认的:数组()
这是最基本的方法来指定应该使用的选择。的选择
选择是一个数组,数组的键是项目值和数组值项的标签:
1 2 3
美元构建器- >add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”)));
提示
当可供选择的值不是整数或字符串(但如漂浮或布尔值),你应该使用choice_list选项。采用这一选项你可以保持原始数据格式是重要的,以确保用户正确输入验证和无用的数据库更新数据类型不匹配引起的避免。
choice_list
这是一种指定选项用于这一领域。的choice_list
选择必须的一个实例ChoiceListInterface
。为更先进的情况下,可以创建一个自定义的类实现接口提供的选择。
使用这个选项您可以也允许选为浮点值数据。
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\扩展\核心\ChoiceList\ChoiceList;/ /……美元构建器- >add (“状态”,“选择”,数组(“choice_list”= >新ChoiceList (数组(1,0.5),数组(“全部”,“一半”))));
empty_value
2.3
因为Symfob娱乐下载ony 2.3还支持如果空值扩大
选项设置为true。
类型:字符串
或布尔
这个选项决定是否一个特殊的“空”选项(如。“选择一个选项”)将出现在顶部的选择小部件。此选项仅适用于如果多个
选项设置为false。
添加一个空值与“选择一个选项”:
1 2 3
美元构建器- >add (“州”,“选择”,数组(“empty_value”= >选择一个选项的));
保证没有“空”的价值选择是显示:
1 2 3
美元构建器- >add (“州”,“选择”,数组(“empty_value”= >假));
如果你离开empty_value
选项设置,然后一个空白(无文本)选项将自动添加当且仅当要求
选项是错误的:
1 2 3 4
/ /一个空白(没有文本)选项将被添加美元构建器- >add (“州”,“选择”,数组(“要求”= >假));
preferred_choices
类型:数组
默认的:数组()
如果指定这个选项,然后是一个子集的所有选项将移动到顶部的选择菜单。以下将“巴兹”选项,与视觉之间的分隔符,其余的选项:
1 2 3 4
美元构建器- >add (“foo_choices”,“选择”,数组(“选择”= >数组(“foo”= >“Foo”,“酒吧”= >“酒吧”,“记者”= >“记者”),“preferred_choices”= >数组(“记者”)));
注意,当呈现作为优先选择才有其意义选择
元素(即。扩大
是假的)。优先选择和正常的选择是由一组分离视觉虚线(即。- - - - - - - - - - - - - - - - - - -
)。这可以定制在呈现字段:
1
{{form_widget(形式。foo_choices,{“分离器”:“= = = = = '})}}
1
< ? php回声美元视图(“形式”]- >小部件(美元形式(“foo_choices”),数组(“分隔符”= >“= = = = =”))? >
覆盖选项
empty_data
类型:混合
DEFAULT_PLACEHOLDER
这个选项决定了什么值字段提交时将返回值是空的。
但是你可以定制您的需求。例如,如果你想要的性别
选择字段是显式地设置零
当选择没有价值,你可以这样做:
1 2 3 4 5 6 7 8 9
美元构建器- >add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”),“要求”= >假,“empty_value”= >“选择你的性别”,“empty_data”= >零));
这个选项的默认值取决于其他字段选项:
- 如果
多个
是假
和扩大
是假
,然后”
(空字符串); - 否则
数组()
(空数组)。
empty_data
类型:混合
DEFAULT_PLACEHOLDER
这个选项决定了什么值字段提交时将返回值是空的。
但是你可以定制您的需求。例如,如果你想要的性别
选择字段是显式地设置零
当选择没有价值,你可以这样做:
1 2 3 4 5 6 7 8 9
美元构建器- >add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”),“要求”= >假,“empty_value”= >“选择你的性别”,“empty_data”= >零));
继承的选项
这些选项的继承形式类型:
by_reference
类型:布尔
默认的:真正的
在大多数情况下,如果你有一个的名字
场,然后你期望setName ()
被称为底层对象。然而,在某些情况下,setName ()
可能不被称为。设置by_reference
在所有情况下确保调用setter。
进一步解释这个,这里有一个简单的例子:
1 2 3 4 5 6 7 8
美元构建器=美元这- >createFormBuilder (美元文章);美元构建器- >add (“标题”,“文本”)- >add (美元构建器- >创建(“作者”,“形式”,数组(“by_reference”= > ?)- >add (“名字”,“文本”)- >add (“电子邮件”,“电子邮件”))
如果by_reference
是真的,以下发生在幕后当你打电话吗提交()
(或handleRequest ()
)形式:
1 2 3
美元文章- >setTitle (“……”);美元文章- >getAuthor ()- >setName (“……”);美元文章- >getAuthor ()- >setEmail (“……”);
请注意,setAuthor ()
不叫。作者通过引用修改。
如果你设置by_reference
为false,提交看起来像这样:
1 2 3 4 5
美元文章- >setTitle (“……”);美元作者=美元文章- >getAuthor ();美元作者- >setName (“……”);美元作者- >setEmail (“……”);美元文章- >setAuthor (美元作者);
所以,所有的by_reference = false
真的是迫使框架调用setter父对象。
类似地,如果您正在使用集合形成你的基础集合数据类型是一个对象(如与学说ArrayCollection
),然后by_reference
必须设置为假
如果你需要加法器和剂(如。addAuthor ()
和removeAuthor ()
)被称为。
数据
类型:混合默认的:默认字段的对象(如果有的话)
当你创建一个表单,最初显示每个字段的值对应的表单的域对象的属性(如果一个对象被绑定到表单)。如果你想覆盖形式的初始值或只是单个字段,你可以设置它在数据选项:
1 2 3
美元构建器- >add (“令牌”,“隐藏”,数组(“数据”= >“六边形abcdef”));
请注意
表单字段的默认值是直接取自底层数据结构(例如,一个实体或数组)。的数据
选择覆盖默认值。
error_mapping
类型:数组
默认的:空
这个选项允许您修改验证错误的目标。
想象你有一个自定义的命名方法matchingCityAndZipCode
验证城市和邮编是否匹配。不幸的是,没有“matchingCityAndZipCode”字段在表单,所以Symfony所能做的一切是显示错误的形式。ob娱乐下载
自定义错误映射,你可以做得更好:误差映射到城市字段以便它上面显示:
1 2 3 4 5 6 7 8
公共函数setDefaultOptions(OptionsResolverInterface美元解析器){美元解析器- >setDefaults (数组(“error_mapping”= >数组(“matchingCityAndZipCode”= >“城市”)));}
这里的规则是左边和右边的映射:
- 左侧包含属性的路径;
- 如果违反上生成一个类的属性或方法,只是它的路径
propertyName
; - 如果违反上生成一个条目的
数组
或ArrayAccess
对象,属性路径(indexName)
; - 您可以构建嵌套属性路径通过连接,分离属性点。例如:
地址[工作].matchingCityAndZipCode
; - 左边的错误映射还接受一个点
。
,指领域本身。这意味着任何错误添加到字段添加到给定的嵌套字段相反; - 右侧包含简单的表单中字段的名称。
inherit_data
2.3
的inherit_data
选项是在Symfony 2.3中引入的。ob娱乐下载之前,它被称为虚拟
。
类型:布尔
默认的:假
这个选项决定了如果表单将继承其父的数据形式。这可能是有用的,如果你有一组字段复制到多个形式。看到如何减少代码重复“inherit_data”。
标签
类型:字符串
默认的:标签是“猜”字段名称
设置标签时,将使用渲染。设置为false将抑制标签。设置标签也可以直接在模板:
1
{{了form_label (form.name '你的名字')}}
1 2 3 4
回声美元视图(“形式”]- >标签(美元形式(“名字”),“你的名字”);
label_attr
类型:数组
默认的:数组()
集的HTML属性<标识>
元素,它将使用时呈现字段的标签。这是一个关联数组与HTML属性作为一个关键。这个属性也可以直接设置在模板:
1
{{了form_label (form.name,“你的名字”,{label_attr:{‘类’:‘CUSTOM_LABEL_CLASS}})}}
1 2 3 4 5
回声美元视图(“形式”]- >标签(美元形式(“名字”),“你的名字”,数组(“label_attr”= >数组(“类”= >“CUSTOM_LABEL_CLASS”)));
要求
类型:布尔
默认的:真正的
如果这是真的,一个HTML5必需属性将会呈现。相应的标签
还将呈现的要求
类。
这是肤浅的和独立的验证。在最好的情况下,如果你让Symfony猜ob娱乐下载你的字段类型,那么这个选项的值将从你的猜测验证信息。
请注意
所需的选择也会影响每个字段是空的数据如何处理。更多细节,请参阅empty_data选择。
场变量
变量 | 类型 | 使用 |
---|---|---|
多个 | 布尔 |
的值多个选择。 |
扩大 | 布尔 |
的值扩大选择。 |
preferred_choices | 数组 |
一个嵌套数组包含ChoiceView 对象的选择应该呈现给用户提供优先级。 |
选择 | 数组 |
一个嵌套数组包含ChoiceView 对象的选择。 |
分隔符 | 字符串 |
选择组之间的分隔符使用。 |
empty_value | 混合 |
空值,如果未在列表中,否则零 。 |
is_selected | 可调用的 |
一个需要一个可调用的ChoiceView 和所选值(s),并返回的选择是是否选中的值(s)。 |
empty_value_in_choices | 布尔 |
空值是否在选择列表中。 |
提示
这是明显更快的使用函数和变量引用树枝模板形式相反,当使用树枝进行测试。