字段类型
编辑本页警告:您正在浏览的文档欧宝官网下载appob娱乐下载Symfony 2.3,现已不再维护。
读本页的更新版本用于Syob娱乐下载mfony 6.2(当前稳定版本)。
字段类型
的形式
类型预定义了两个选项,然后在所有类型上可用形式
父类型。
选项 | |
继承的选项 | |
父 | 没有一个 |
类 | FormType |
场的选择
行动
2.3
的行动
选项在Symfony 2.3中引入。ob娱乐下载
类型:字符串
默认的:空字符串
此选项指定提交表单时将数据发送到哪里(通常是URI)。的值表示为行动
属性。形式
元素。空值被认为是同一个文档引用,即表单将被提交给呈现表单的同一个URI。
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。
类似地,如果你使用集合表单类型,其中您的底层集合数据是一个对象(就像Doctrine的ArrayCollection
),然后by_reference
必须设置为假
如果你需要加法器和移除器(例如。addAuthor ()
而且removeAuthor ()
)被称为。
cascade_validation
类型:布尔
默认的:假
将此选项设置为真正的
强制对嵌入的表单类型进行验证。例如,如果你有一个ProductType
用嵌入式CategoryType
,设置cascade_validation
来真正的
在ProductType
会导致数据来自哪里CategoryType
也要被验证。
提示
不使用此选项,建议使用有效的
约束强制对存储在属性上的子对象进行验证。方法的级联只是验证,而不是使用validation_groups
子表单上的选项。你可以在关于嵌入单个对象.
提示
默认情况下error_bubbling
选项收集字段类型,它将错误传递给父表单。如果要将错误附加到实际发生错误的位置,则必须设置error_bubbling
来假
.
数据
类型:混合
默认的:默认为基础对象的字段(如果有的话)
创建表单时,每个字段最初显示表单域对象的相应属性的值(如果对象绑定到表单)。如果你想覆盖表单的初始值或只是一个单独的字段,你可以在data选项中设置它:
1 2 3
$构建器->add (“令牌”,“隐藏”,数组(“数据”= >“六边形abcdef”));
请注意
表单字段的默认值直接取自底层数据结构(例如,实体或数组)。的数据
选项将覆盖此默认值。
data_class
类型:字符串
此选项用于设置表单要使用的适当数据映射器,因此可以将其用于任何需要对象的表单字段类型。
1 2 3
$构建器->add (“媒体”,“sonata_media_type”,数组(“data_class”= >“Acme \ DemoBundle \实体\媒体”));
empty_data
类型:混合
- . .该文件应该只包含“开始后”或“结束前”
- 设置为此占位符值。它的目的是让我们只包含该文件的一部分。
DEFAULT_PLACEHOLDER
此选项决定了当提交的值为空时字段将返回什么值。
但是您可以根据自己的需要定制它。例如,如果你想要性别
要显式设置的选择字段零
当没有选择值时,你可以这样做:
1 2 3 4 5 6 7 8 9
$构建器->add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”),“要求”= >假,“empty_value”= >“选择性别”,“empty_data”= >零));
该选项的实际默认值取决于其他字段选项:
- 如果
data_class
设置为要求
是真正的
,然后新的data_class美元()
; - 如果
data_class
设置为要求
是假
,然后零
; - 如果
data_class
并没有设置复合
是真正的
,然后数组()
(空数组); - 如果
data_class
并没有设置复合
是假
,然后”
(空字符串)。
empty_data
类型:混合
- . .该文件应该只包含“开始后”或“结束前”
- 设置为此占位符值。它的目的是让我们只包含该文件的一部分。
DEFAULT_PLACEHOLDER
此选项决定了当提交的值为空时字段将返回什么值。
但是您可以根据自己的需要定制它。例如,如果你想要性别
要显式设置的选择字段零
当没有选择值时,你可以这样做:
1 2 3 4 5 6 7 8 9
$构建器->add (“性别”,“选择”,数组(“选择”= >数组(“米”= >“男”,“f”= >“女”),“要求”= >假,“empty_value”= >“选择性别”,“empty_data”= >零));
error_bubbling
类型:布尔
默认的:假
除非表格是复合
如果真正的
,此字段的任何错误都将传递给父字段或表单。例如,如果设置为真正的
对于普通字段,该字段的任何错误都将附加到主表单,而不是特定的字段。
error_mapping
2.1
的error_mapping
选项在Symfony 2.1中引入。ob娱乐下载
类型:数组
默认的:数组()
此选项允许您修改验证错误的目标。
假设您有一个名为matchingCityAndZipCode
这将验证城市和邮政编码是否匹配。不幸的是,您的表单中没有“matchingCityAndZipCode”字段,因此Symfony所能做的就是在表单顶部显示错误。ob娱乐下载
使用自定义错误映射,你可以做得更好:将错误映射到城市字段,这样它就会显示在它上面:
1 2 3 4 5 6 7 8
公共函数setDefaultOptions(OptionsResolverInterface$解析器){$解析器->setDefaults (数组(“error_mapping”= >数组(“matchingCityAndZipCode”= >“城市”,),));}
下面是映射左侧和右侧的规则:
- 左侧包含属性路径;
- 如果违反是在类的属性或方法上生成的,则其路径简单
propertyName
; - 类的项上生成的违例
数组
或ArrayAccess
对象时,属性路径为(indexName)
; - 您可以通过连接它们来构造嵌套的属性路径,用圆点分隔属性。例如:
地址[工作].matchingCityAndZipCode
; - 右侧仅包含表单中字段的名称。
默认情况下,任何未映射的属性的错误都会冒泡到父表单。你可以用点(.
),将所有未映射属性的错误映射到特定字段。例如,将所有这些错误映射到城市
字段中,使用:
1 2 3 4 5
$解析器->setDefaults (数组(“error_mapping”= >数组(“。”= >“城市”,),));
extra_fields_message
类型:字符串
默认的:此表单不应包含额外字段。
这是验证错误消息,如果提交的表单数据包含一个或多个不属于表单定义的字段,则使用该消息。占位符{{extra_fields}}
可用于显示以逗号分隔的提交的额外字段名称列表。
inherit_data
2.3
的inherit_data
选项在Symfony 2.3中引入。ob娱乐下载以前,它被称为虚拟
.
类型:布尔
默认的:假
此选项决定表单是否从其父表单继承数据。如果您有一组跨多个表单重复的字段,这可能很有用。看到如何使用"inherit_data"减少代码重复.
谨慎
字段具有inherit_data
选项集时,它按原样使用父表单的数据。这意味着数据变形金刚不会被应用到那个领域。
invalid_message
类型:字符串
默认的:此值无效
这是验证错误消息,如果输入到该字段的数据没有意义(即验证失败),将使用该消息。
例如,如果用户将无意义的字符串输入到时间字段不能转换为实时的,或者如果用户输入字符串(例如。苹果
)转换为数字字段。
正常(业务逻辑)验证(例如在设置字段的最小长度时)应该使用验证消息和验证规则(参考).
invalid_message_parameters
类型:数组
默认的:数组()
当设置invalid_message
选项时,您可能需要在字符串中包含一些变量。这可以通过在该选项中添加占位符并包括该选项中的变量来实现:
1 2 3 4 5
$构建器->add (“some_field”,“some_type”,数组(/ /……“invalid_message”= >'您输入的值无效,它应该包含%num%字母',“invalid_message_parameters”= >数组(“% num %”= >6)));
label_attr
类型:数组
默认的:数组()
属性的HTML属性<标识>
元素,它将在呈现字段的标签时使用。它是一个以HTML属性为键的关联数组。这些属性也可以直接在模板中设置:
- 嫩枝
- PHP
1 2 3
{{form_label(form.name, '您的名字',{' label_attr': {'class': 'CUSTOM_LABEL_CLASS'}})}}
1 2 3 4 5
回声$视图[“形式”]->标签($形式[“名字”),“你的名字”,数组(“label_attr”= >数组(“类”= >“CUSTOM_LABEL_CLASS”)));
方法
2.3
的方法
选项在Symfony 2.3中引入。ob娱乐下载
类型:字符串
默认的:帖子
此选项指定用于提交表单数据的HTTP方法。的值表示为方法
属性。形式
元素中的表单提交,用于决定是否处理handleRequest ()
提交后的方法。可能取值为:
- 帖子
- 得到
- 把
- 删除
- 补丁
请注意
当方法为PUT、PATCH或DELETE时,Symfony将自动呈现一个ob娱乐下载_method
表单中的隐藏字段。这用于“伪造”这些HTTP方法,因为标准浏览器不支持这些方法。有关更多信息,请参见如何在路由中使用GET和POST之外的HTTP方法.
请注意
PATCH方法允许提交部分数据。换句话说,如果提交的表单数据缺少某些字段,这些字段将被忽略,并使用默认值(如果有的话)。对于所有其他HTTP方法,如果提交的表单数据缺少某些字段,则将这些字段设置为零
.
模式
类型:字符串
默认的:零
这就增加了一个HTML5模式
属性通过给定正则表达式限制字段输入。
谨慎
的模式
属性仅为方便的目的提供客户端验证,不能用于替代可靠的服务器端验证。
请注意
在使用验证约束时,会自动为某些约束设置此选项,以匹配服务器端验证。
post_max_size_message
类型:字符串
默认的:上传的文件过大。请尝试上传一个小一点的文件。
这是验证错误消息,如果提交的POST表单数据超过php . ini
的post_max_size
指令。的{{Max}}
占位符可以用来显示允许的大小。
请注意
验证post_max_size
只发生在根形式。
property_path
类型:任何
默认的:字段名
默认情况下,字段显示表单域对象的属性值。当表单提交时,提交的值被写回对象中。
如果要重写字段读取和写入的属性,可以设置property_path
选择。它的默认值是字段的名称。
如果希望在读取或写入对象时忽略该字段,则可以设置property_path
选项假
,但使用property_path
已弃用,您应该使用映射
选择。
2.1
的映射
选项是在Symfony 2.1中为此用例引入的。ob娱乐下载
要求
类型:布尔
默认的:真正的
如果为,则HTML5所需属性将被渲染。相应的标签
还会渲染一个要求
类。
这是肤浅的,独立于验证。如果您让Symfony猜测您的字段类型,ob娱乐下载那么这个选项的值将从您的验证信息中猜测出来。
请注意
必选选项还影响如何处理每个字段的空数据。有关详细信息,请参见empty_data选择。
继承的选项
属性中定义了以下选项基类型类。的基类型
类的父类形式
类型和按钮类型,但它不是表单类型树的一部分(即它不能单独用作表单类型)。
attr
类型:数组
默认的:数组()
属性,可以向HTML字段表示形式添加额外属性attr
选择。它是一个以HTML属性为键的关联数组。当你需要为某个小部件设置自定义类时,这可能很有用:
1 2 3
$构建器->add (“身体”,“文本区域”,数组(“attr”= >数组(“类”= >“tinymce”)));
标签
类型:字符串
默认的:从字段名“猜测”标签
设置呈现字段时将使用的标签。设置为false将屏蔽标签。标签也可以直接在模板内设置:
- 嫩枝
- PHP
1
{{form_label(form.name, '你的名字')}}
1 2 3 4
回声$视图[“形式”]->标签($形式[“名字”),“你的名字”);