日期字段类型

编辑该页面

警告:你浏览的文档欧宝官网下载appob娱乐下载Symfony 2.1,不再维护。

这个页面的更新版本Symfob娱乐下载ony 6.2(当前的稳定版本)。

日期字段类型

一个字段,允许用户修改日期信息通过各种不同的HTML元素。

底层数据用于这个领域可以是一个类型DateTime对象,一个字符串,一个时间戳或数组。只要输入正确选项设置,该领域将照顾所有的细节。

字段可以呈现为一个文本框,三个文本框(月,一天,和年)或三个选择框(见“widget_”选项)。

基本数据类型 可以DateTime,时间戳字符串或数组(请参阅输入选项)
呈现为 单一的文本框或三个选择字段
选项
覆盖选项
继承的选项
父类型 (如果文本),形式否则
DateType

基本用法

这个字段类型是高度可配置的,但易于使用。最重要的选项输入小部件

假设你有一个publishedAt字段是一个潜在的日期DateTime对象。下面的配置日期这个字段的类型为三个不同的选择字段:

1 2 3 4
美元构建器- >add (“publishedAt”,“日期”,数组(“输入”= >“datetime”,“部件”= >“选择”));

输入选项必须被改变的底层日期数据类型相匹配。例如,如果publishedAt字段的数据是一个unix时间戳,你需要设置输入时间戳:

1 2 3 4
美元构建器- >add (“publishedAt”,“日期”,数组(“输入”= >“时间戳”,“部件”= >“选择”));

还支持一个数组字符串作为有效的输入选项值。

场的选择

小部件

类型:字符串默认的:选择

这个字段应该呈现的基本方法。可以是下列之一:

  • 选择:呈现三个选择输入。选择的顺序中定义格式选择。
  • 文本:呈现三个字段输入类型的文本(月,日,年)。
  • single_text:呈现一个输入类型的日期在Symfony 2.0(文本)。ob娱乐下载用户的
    输入的基础上进行验证格式选择。

输入

类型:字符串默认的: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本身

empty_value

类型:字符串数组

如果你的小部件选项设置为选择,那么这个字段将被表示为一系列的选择盒子。的empty_value选项可用于添加一个“空白”条目的每一个选择框:

1 2 3
美元构建器- >add (“dueDate”,“日期”,数组(“empty_value”= >));

此外,您可以指定一个字符串显示为“空白”的值:

1 2 3
美元构建器- >add (“dueDate”,“日期”,数组(“empty_value”= >数组(“年”= >“年”,“月”= >“月”,“天”= >“天”)));

类型:数组默认的:前五年,五年之后

今年年可用字段类型列表。这个选项只有相关时小部件选项设置为选择

个月

类型:数组默认的:1到12

个月每月可用字段类型列表。这个选项只有相关时小部件选项设置为选择

类型:数组默认的:1至31日

天一天可用字段类型列表。这个选项只有相关时小部件选项设置为选择:

1
“天”= >范围(1,31日)

格式

类型:整数字符串默认的:IntlDateFormatter::中等

选项传递给IntlDateFormatter类,用于将用户输入转换为适当的格式。当这是至关重要的小部件选项设置为single_text,并将定义用户如何将输入数据。默认情况下,格式是基于当前用户语言环境:决定意义为不同的用户预期的格式将会不同。你可以通过覆盖作为字符串的格式。

有效格式的更多信息,请参阅日期/时间格式语法。例如,呈现一个文本框,预计用户输入yyyy-MM-dd,请使用以下选项:

1 2 3 4
美元构建器- >add (“date_created”,“日期”,数组(“部件”= >“single_text”,“格式”= >“yyyy-MM-dd”));

data_timezone

类型:字符串默认的:系统默认时区

输入数据存储在时区。这一定是其中一个PHP支持时区

user_timezone

类型:字符串默认的:系统默认时区

时区的数据应该显示给用户(因此也用户提交的数据)。这一定是其中一个PHP支持时区

覆盖选项

by_reference

默认的:

DateTime被视为不可变对象类。

error_bubbling

默认的:

继承的选项

这些选项的继承类型:

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)));

read_only

2.1

read_only选择是改变2.1年来呈现只读的HTML属性。以前,它呈现为一个禁用属性。使用禁用选择如果你需要旧的行为。

类型:布尔默认的:

如果这个选项是真的,该领域将呈现只读的属性字段不可编辑。

禁用

2.1

禁用选择是新的2.1版本中

类型:布尔默认的:

如果你不想让用户修改一个字段的值,您可以设置
禁用的选项为true。任何提交的值将被忽略。

映射

类型:布尔

如果你希望这个领域被忽略阅读或写作对象时,你可以设置映射选项

虚拟

类型:布尔默认的:

这个选项决定了如果表单将映射数据。这可能是有用的,如果你需要一种形式结构的视图。看到如何使用虚拟表单字段选择吗

2.1

error_mapping选择新Symfony 2.1。ob娱乐下载

error_mapping

类型:数组默认的:

这个选项允许您修改验证错误的目标。

想象你有一个自定义的命名方法matchingCityAndZipCode验证城市和邮编是否匹配。不幸的是,没有“matchingCityAndZipCode”
在表单字段,所以Symfony所能做的一切是显示错误的形式。ob娱乐下载

自定义错误映射,你可以做得更好:误差映射到城市字段以便它上面显示:

1 2 3 4 5 6 7 8
公共函数setDefaultOptions(OptionsResolverInterface美元解析器){美元解析器- >setDefaults (数组(“error_mapping”= >数组(“matchingCityAndZipCode”= >“城市”)));}

这里的规则是左边和右边的映射:

  • 左侧包含属性的路径。
  • 如果违反上生成一个类的属性或方法,它的路径是“propertyName”。
  • 如果违反上生成一个条目的数组ArrayAccess对象,属性路径(indexName)
  • 您可以构建嵌套属性路径通过连接,分离属性点。例如:地址[工作].matchingCityAndZipCode
  • 左边的错误映射还接受一个点,指领域本身。这意味着任何错误添加到字段添加到给定的嵌套的字段。
  • 右侧包含简单的表单中字段的名称。
这项工作,包括代码示例,许可下Creative Commons冲锋队3.0许可证。