TimeType领域
编辑该页面TimeType领域
一个字段输入捕获时间。
这可以呈现为一个文本字段,一系列的文本字段(如小时、分钟、秒)或一系列选择字段。可以存储为底层数据DateTime
对象,一个字符串,一个时间戳或数组。
基本数据类型 | 可以DateTime ,时间戳字符串或数组(请参阅输入 选项) |
呈现为 | 可以各种标记(见下文) |
默认的无效信息 | 请输入一个有效的时间。 |
遗留无效的信息 | {{value}}的值是无效的。 |
父类型 | FormType |
类 | TimeType |
提示
选项的完整列表和继承了这种类型定义在你的应用可以运行这个命令:
1 2
#替换“FooType”的表单类型的类名美元php bin /控制台调试:FooType形式
基本用法
最重要的选项输入
和小部件
。
假设你有一个开始时间
领域的潜在的时间数据DateTime
对象。下面的配置TimeType
该字段作为两个不同的选择字段:
1 2 3 4 5 6 7
使用ob娱乐下载\组件\形式\扩展\核心\类型\TimeType;/ /……美元构建器- >add (“开始时间”,TimeType::类,“输入”= >“datetime”,“部件”= >“选择”]);
的输入
选项必须被改变的底层日期数据类型相匹配。例如,如果开始时间
字段的数据是一个unix时间戳,你需要设置输入
来时间戳
:
1 2 3 4 5 6 7
使用ob娱乐下载\组件\形式\扩展\核心\类型\TimeType;/ /……美元构建器- >add (“开始时间”,TimeType::类,“输入”= >“时间戳”,“部件”= >“选择”]);
还支持一个数组
和字符串
作为有效的输入
选项值。
场的选择
choice_translation_domain
类型:字符串
,布尔
或零
默认的:假
这个选项决定了如果选择值应该翻译和翻译领域。
的值choice_translation_domain
选项可以真正的
(重用当前翻译域),假
(禁用翻译),零
(使用翻译父域或默认域)或一个字符串代表确切的翻译领域使用。
占位符
类型:字符串
|数组
如果你的小部件选项设置为选择
,那么这个字段将被表示为一系列的选择
盒子。当占位符的值是一个字符串,它将被用作空白值所有的选择框:
1 2 3
美元构建器- >add (“开始时间”,“时间”,(“占位符”= >“选择一个值”]);
或者,您可以使用一个数组,配置不同的占位符值小时,分钟和第二个字段:
1 2 3 4 5
美元构建器- >add (“开始时间”,“时间”,(“占位符”= > [“小时”= >“小时”,“一分钟”= >“一分钟”,“第二”= >“第二”、]]);
html5
类型:布尔
默认的:真正的
如果这个设置真正的
(默认),它将使用HTML5类型(日期、时间或datetime-local)呈现。当设置为假
,它将使用文本类型。
这是非常有用的,当你想使用一个定制的JavaScript datepicker,通常需要一个文本类型而不是一个HTML5类型。
输入
类型:字符串
默认的:datetime
的格式输入数据——例如,日期的格式存储在你的潜在对象。有效值:
字符串
(如。12:17:26
)datetime
(一个DateTime
对象)datetime_immutable
(一个DateTimeImmutable
对象)数组
(如。(“小时”= > 12,“分钟”= > 17日'第二' = > 26)
)时间戳
(如。1307232000
)
回来从表单的价值也将归一化回这种格式。
model_timezone
类型:字符串
默认的:系统默认时区
输入数据存储在时区。这一定是其中一个PHP支持时区。
谨慎
当使用不同的值model_timezone
和view_timezone,一个reference_date必须配置。
reference_date
类型:DateTimeInterface
默认的:零
配置一个参考日期时是必需的model_timezone和view_timezone是不同的。时区转换将根据这个日期计算。
view_timezone
类型:字符串
默认的:系统默认时区
时区的数据应该显示给用户(因此也用户提交的数据)。这一定是其中一个PHP支持时区。
当没有reference_date是设置view_timezone
默认配置的model_timezone。
谨慎
当使用不同的值model_timezone和view_timezone
,一个reference_date必须配置。
小部件
类型:字符串
默认的:选择
这个字段应该呈现的基本方法。可以是下列之一:
选择
(默认):呈现一个,两个或三个选择输入(小时、分钟、秒),根据with_minutes和with_seconds选项。文本
(默认):呈现一个,两个或三个文本输入(小时、分钟、秒),根据with_minutes和with_seconds选项。single_text
:呈现一个输入的类型时间
。用户的输入将会对表单进行验证hh: mm
(或hh: mm: ss
如果使用秒)。
谨慎
结合小部件类型single_text
和with_minutes选项设置为假
可能导致不可预测的行为在客户端作为输入类型时间
可能不支持只选择一个小时。
覆盖选项
data_class
类型:字符串
默认的:零
这种类型的内部规范化表示是一个数组,而不是一个\ DateTime
对象。因此,data_class
选择初始化零
为了避免FormType
对象初始化\ DateTime
。
error_bubbling
默认的:假
invalid_message
类型:字符串
默认的:这个值是无效的
这是验证错误消息,如果数据使用进入这个领域没有意义(即未验证)。
这可能发生,例如,如果用户输入一个无意义的字符串TimeType字段不能被转换成实时或如果用户输入一个字符串(例如苹果
)进入很多领域。
正常(业务逻辑)验证(例如当设置一个最小长度字段)应设置使用验证消息的验证规则(参考)。
继承的选项
这些选项的继承FormType:
attr
类型:数组
默认的:[]
如果你想添加额外的属性可以使用HTML字段表示attr
选择。这是一个与HTML属性关联数组的键。这可能是有用的,当你需要设置一个自定义类部件:
1 2 3
美元构建器- >add (“身体”,TextareaType::类,“attr”= > [“类”= >“tinymce”)));
另请参阅
使用row_attr
选择如果你想将这些属性添加到表单类型行元素。
数据
类型:混合
默认的:默认字段的底层结构。
当你创建一个表单,最初显示每个字段的值对应的表单的域数据的属性(例如,如果您将对象绑定到表单)。如果你想覆盖这个表单或单个字段的初始值,你可以设置它在数据选项:
1 2 3 4 5 6
使用ob娱乐下载\组件\形式\扩展\核心\类型\HiddenType;/ /……美元构建器- >add (“令牌”,HiddenType::类,“数据”= >“六边形abcdef”]);
谨慎
的数据
选项总是覆盖的值从域数据(对象)呈现。这意味着对象的值也覆盖当表单编辑已经持久化的对象,使其在表单提交时失去保存价值。
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”= > [“。”= >“城市”、]]);
帮助
类型:字符串
或TranslatableInterface
默认的:零
允许您定义一个表单字段的帮助信息,默认情况下是呈现以下字段:
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 ()),“存储”)));
6.2
支持TranslatableInterface
对象作为帮助内容是在Symfony 6.2中引入的。ob娱乐下载
help_attr
类型:数组
默认的:[]
设置元素的HTML属性用于显示帮助信息的表单字段。它的值是一个关联数组与HTML属性名称作为键。这些属性也可以在模板设置:
1 2 3
{{form_help (form.name,“你的名字”,{help_attr:{‘类’:‘CUSTOM_LABEL_CLASS}})}}
inherit_data
类型:布尔
默认的:假
这个选项决定了如果表单将继承其父的数据形式。这可能是有用的,如果你有一组字段复制到多个形式。看到如何减少代码重复“inherit_data”。
谨慎
当一个字段inherit_data
选项设置,它使用父窗体的数据。这意味着数据变形金刚不会被应用到这一领域。
invalid_message_parameters
类型:数组
默认的:[]
当设置invalid_message
选项,您可能需要包括一些变量的字符串。这可以通过添加占位符选项,在该选项包括变量:
1 2 3 4 5
美元构建器- >add (“someField”,SomeFormType::类,/ /……“invalid_message”= >您输入一个无效的值,它应该包括% num %字母的,“invalid_message_parameters”= > [“% num %”= >6)));
表单变量
变量 | 类型 | 使用 |
---|---|---|
小部件 | 混合 |
的值小部件选择。 |
with_minutes | 布尔 |
的值with_minutes选择。 |
with_seconds | 布尔 |
的值with_seconds选择。 |
类型 | 字符串 |
只有当小部件single_text HTML5是激活的,包含要使用的输入类型(datetime ,日期 或时间 )。 |