日期字段类型
编辑该页面警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 2.4,不再维护。
读这个页面的更新版本Symfob娱乐下载ony 6.3(当前的稳定版本)。
日期字段类型
一个字段,允许用户修改日期信息通过各种不同的HTML元素。
底层数据用于这个领域可以是一个类型DateTime
对象,一个字符串,一个时间戳或数组。只要输入正确选项设置,该领域将照顾所有的细节。
字段可以呈现为一个文本框,三个文本框(月,一天,和年)三个选择框(见小部件选项)。
基本用法
这个字段类型是高度可配置的,但易于使用。最重要的选项输入
和小部件
。
假设你有一个publishedAt
字段是一个潜在的日期DateTime
对象。下面的配置日期
这个字段的类型为三个不同的选择字段:
1 2 3 4
美元构建器- >add (“publishedAt”,“日期”,数组(“输入”= >“datetime”,“部件”= >“选择”));
的输入
选项必须被改变的底层日期数据类型相匹配。例如,如果publishedAt
字段的数据是一个unix时间戳,你需要设置输入
来时间戳
:
1 2 3 4
美元构建器- >add (“publishedAt”,“日期”,数组(“输入”= >“时间戳”,“部件”= >“选择”));
还支持一个数组
和字符串
作为有效的输入
选项值。
场的选择
empty_value
类型:字符串
或数组
如果你的小部件选项设置为选择
,那么这个字段将被表示为一系列的选择
盒子。的empty_value
选项可用于添加一个“空白”条目的每一个选择框:
1 2 3
美元构建器- >add (“dueDate”,“日期”,数组(“empty_value”= >”));
此外,您可以指定一个字符串显示为“空白”的值:
1 2 3
美元构建器- >add (“dueDate”,“日期”,数组(“empty_value”= >数组(“年”= >“年”,“月”= >“月”,“天”= >“天”)));
格式
类型:整数
或字符串
默认的:IntlDateFormatter::中等(或yyyy-MM-dd
如果小部件是single_text
)
选项传递给IntlDateFormatter
类,用于将用户输入转换为适当的格式。当这是至关重要的小部件选项设置为single_text
,并将定义用户如何将输入数据。默认情况下,格式是基于当前用户语言环境:决定意义为不同的用户预期的格式将会不同。你可以通过覆盖作为字符串的格式。
有效格式的更多信息,请参阅日期/时间格式语法:
1 2 3 4 5
美元构建器- >add (“date_created”,“日期”,数组(“部件”= >“single_text”,/ /这是single_text默认格式“格式”= >“yyyy-MM-dd”));
请注意
如果你想要你的领域呈现为一个HTML5“日期”字段,你必须使用一个single_text
小部件的yyyy-MM-dd
格式(RFC 3339格式)如果你使用默认值single_text
小部件。
输入
类型:字符串
默认的:datetime
的格式输入数据——例如,日期的格式存储在你的潜在对象。有效值:
字符串
(如。2011-06-05
)datetime
(一个DateTime
对象)数组
(如。数组(2011 '年' = > '月' = > 06,'天' = > 05)
)时间戳
(如。1307232000
)
回来从表单的价值也将归一化回这种格式。
谨慎
如果时间戳
使用,DateType
星期五之间仅限于日期,1901年12月13日格林尼治时间20:45:54,星期二,2038年1月19日格林尼治时间03:14:07在32位系统上。这是由于限制在PHP本身。
继承的选项
这些选项的继承形式类型:
数据
类型:混合默认的:默认字段的对象(如果有的话)
当你创建一个表单,最初显示每个字段的值对应的表单的域对象的属性(如果一个对象被绑定到表单)。如果你想覆盖形式的初始值或只是单个字段,你可以设置它在数据选项:
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”。
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)));