Zend_Date-Overview.xml 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786
  1. <sect1 id="zend.date.overview">
  2. <title>Zend_Date API 概述</title>
  3. <para>
  4. 虽然 <code>Zend_Date</code> API 简单并单一,但是通过操作和操作数的丰富组合,它的设计灵活而强大。
  5. </para>
  6. <sect2 id="zend.date.options">
  7. <title>Zend_Date 选项</title>
  8. <sect3 id="zend.date.options.formattype">
  9. <title>选择日期格式类型</title>
  10. <para>
  11. 有若干方法使用日期格式串,和 PHP 的 <code>date()</code> 类似。如果你觉得用 PHP 的日期格式指示器( specifier) 比用 ISO 格式指示器舒服,
  12. 那么你可以使用 <code>Zend_Date::setOptions(array('format_type' => 'php'))</code> 。
  13. 然后,对所有接受 <code>$format</code> 参数的函数使用 PHP 的日期格式指示器。
  14. 使用 <code>Zend_Date::setOptions(array('format_type' => 'iso'))</code> 来切换回只支持 ISO 日期格式的缺省模式。
  15. 所支持格式代码,参见 <xref linkend="zend.date.constants.phpformats" />
  16. </para>
  17. </sect3>
  18. <sect3 id="zend.date.options.fixdst">
  19. <title>DST 和日期数学 </title>
  20. <para>
  21. 当处理日期时,有时候需要考虑 DST(夏令时)更改的影响,一般是加上或减去一个小时。例如,在DST更改前加
  22. 上月份到日期,如果结果是在DST更改之后,那么结果将会多或少一个小时。对于边界日期,如一个月的第一天或
  23. 最后一天的午夜,添加足够的月份数来跨国日期边界会导致日期丢失一个小时并变成前面月份的最后一个小时,出现 "off by 1" 错误。
  24. 为了避免这个情况发生,通过使用 <code>fix_dst</code> 选项来忽略 DST 更改。当跨过夏天/冬天 DST 边界,一般要加减一个小时。
  25. 例如,如果日期的时间部分是 00:00:00, 日期算术跨过春季 DST 会导致日期比预期少一天。
  26. 因为 Zend_Date 基于时间戳,而不是带有时间组件的日历日期,时间戳丢失一个小时导致日期在日历天上比预期少一天。
  27. 为了防止这样的问题,使用选项 <code>fix_dst</code>,它缺省为 true,这样 DST 在日期“算术”(<code>addMOnth(), subMonth()</code>)里无效。
  28. 当执行日期“算术“,使用 <code>Zend_Date::setOptions(array('fix_dst' => false))</code> 使日期加减考虑 DST 的调整。
  29. </para>
  30. <para>
  31. <emphasis role="strong">如果在<code>Zend_Date</code>实例里的当前时区设置为 UTC 或 GMT, 就不用 <code>'fix_dst'</code> 选项</emphasis>,
  32. 这是因为这两个时区和 DST 没有关系。当你又为这个实例的时区修改为不是 UTC 或 GMT 的时区,那么先前设置的 'fix_dst'选项将用于日期“算术”。
  33. </para>
  34. </sect3>
  35. <sect3 id="zend.date.options.extendmonth">
  36. <title>月份计算</title>
  37. <para>
  38. 当从一个日期加减月份时,如果原来的日期接近月末,结果在某月的某天可能不是所期望的。
  39. 例如,当 1月31日加上1个月是,熟悉 SQL的人将以为结果是 2月28日。另一方面,熟悉 Excel 和 OpenOffice的人将认为结果是 3月3日。
  40. 这种问题只发生在这样的情况下:结果的月份里没有原来的月份的某天。
  41. 对于 ZF 的开发者来说,使用 <code>extend_month</code> 选项,当它为 false,就用 SQL 的方式,当它为 true,就用电子表格(如 Excel) 的方式。
  42. <code>extend_month</code> 的缺省值为 false,和 SQL 方式兼容。
  43. 缺省地,<code>Zend_Date</code> 通过截取日期的月末部分(如果有必要)来计算月份,当原始日期指定这个月的某天超过结果月的天数时,不需要把它包含到下个月。
  44. 使用 <code>Zend_Date::setOptions(array('extend_month' => true));</code> 使月份计算就像流行的电子表格程序(如 Excel)一样。
  45. </para>
  46. </sect3>
  47. <sect3 id="zend.date.options.cache">
  48. <title> 用 Zend_Cache 加速日期本地化和标准化 </title>
  49. <para>
  50. 通过使用 <code>Zend_Cache</code> 适配器,你可以加速 <code>Zend_Date</code> 的运算。当你使用本地化的数据,<code>Zend_Date</code> 的所有方法都会加速。
  51. 例如所有接受 <code>Zend_Date::DATE</code> 和 <code>Zend_Date::TIME</code> 常量的方法将会从中受益。
  52. 用 <code>Zend_Date::setOptions(array('cache' => $adapter));</code> 就可给 <code>Zend_Date</code> 设置一个 <code>Zend_Cache</code> 适配器。
  53. </para>
  54. </sect3>
  55. <sect3 id="zend.date.options.timesync">
  56. <title> 用 Zend_TimeSync 同步时间戳 </title>
  57. <para>
  58. 一般来说服务器和计算机上的时钟都不相同。<code>Zend_TimeSync</code> 帮助 <code>Zend_Date</code> 来处理这样的问题。
  59. 你可以用 <code>Zend_Date::setOptions(array('timesync' => $timeserver));</code> 来设置一个时间服务器,
  60. 它将为所有 Zend_Date 的实例设置自己的实际时间戳和真实的实际时间戳之间的偏移量。使用这个选项不修改已存在的实例的时间戳。
  61. 最好的用法是在引导(bootstrap)文件里设置它。
  62. </para>
  63. </sect3>
  64. </sect2>
  65. <sect2 id="zend.date.values">
  66. <title> 使用日期值 </title>
  67. <para>
  68. 一旦通过生成 <code>Zend_Date</code> 对象格式化输入,它就携带一个时区,但在内部用标准的 <ulink url="http://en.wikipedia.org/wiki/Unix_Time">UNIX 时间戳</ulink> 来表示。
  69. 为了使日期能够本地化解析,必需知道时区。缺省的时区总是 GMT/UTC。用 <code>getTimeZone())</code> 来检查对象的时区。
  70. 用 <code>setTimeZone())</code> 来修改对象的时区。这些对象的所有处理都假定和这个时区相关。
  71. </para>
  72. <para>
  73. 要小心不同时区之间的对象的混合和日期部件的匹配操作,它可能会产生不期望的结果,除非运算只和时间戳相关。
  74. 除了上述的情况,<code>Zend_Date</code> 对象的操作会处理不同的时区,因为在 <code>Zend_Date</code> 初始化时日期被格式化成时间戳。
  75. </para>
  76. <para>
  77. 大部分方法需要一个常量来选择需要的日期的<code>$part</code> ,例如 <code>Zend_Date::HOUR</code> 。
  78. 这些常量对下面的所有函数有效,常数列表参见这里 <xref linkend="zend.date.constants.list" /> 。
  79. 如果没有指定 <code>$part</code>,就使用 <code>Zend_Date::TIMESTAMP</code>。另外,也可以对 <code>$part</code> 使用用户指定的格式,
  80. 和 <link linkend="zend.locale.date.normalize"><code>Zend_Locale_Format::getDate()</code></link> 的基本机制和格式一样。
  81. 如果日期对象用明显的无效日期(如大于12的月份)来构造,那么 <code>Zend_Date</code> 将抛出异常,除非没有指定日期格式。例如,
  82. <code>$part</code> 是 <code>null</code> 或者 <code>Zend_Date::DATES</code> ("宽松" 格式) 。
  83. </para>
  84. <example id="zend.date.values.example-1">
  85. <title> 用户指定的日期输入格式 </title>
  86. <programlisting role="php"><![CDATA[
  87. $date1 = new Zend_Date('Feb 31, 2007', null, 'en_US');
  88. echo $date1, "\n"; // outputs "Mar 3, 2007 12:00:00 AM"
  89. $date2 = new Zend_Date('Feb 31, 2007', Zend_Date::DATES, 'en_US');
  90. echo $date2, "\n"; // outputs "Mar 3, 2007 12:00:00 AM"
  91. // strictly restricts interpretation to specified format
  92. $date3 = new Zend_Date('Feb 31, 2007', 'MM.dd.yyyy');
  93. echo $date3, "\n"; // outputs "Mar 3, 2007 12:00:00 AM"
  94. ]]>
  95. </programlisting>
  96. </example>
  97. <para>
  98. 如果提供了可选的 <code>$locale</code> 参数,那么 <code>$locale</code> 通过给 <code>$date</code> 操作数替换月和星期名来消除它的歧义,
  99. 即使根据那个地方的约定来解析日期字符串 (参见 <code><link linkend="zend.locale.date.normalize">Zend_Locale_Format::getDate()</link></code>)。
  100. 当 <code>$part</code> 是 <code>Zend_Date::DATE*</code> 或 <code>Zend_Date::TIME*</code> 常量其中之一,本地化的字符串类型的 <code>$date</code> 就自动格式化。
  101. 如果 <code>$date</code> 是包含日期的字符串,语言的地方标识符要用来解析月和星期的名字。
  102. 如果没有 <code>$date</code> 输入参数,那么 <code>$locale</code> 参数指定地方来用于本地化输出(例如,日期格式的字符串表示)。
  103. 注意 <code>$date</code> 输入参数可能实际有类型名 (例如 <code>$hour</code> 对于 <code>addHour()</code>),尽管它不能防止用 <code>Zend_Date</code> 对象作为参数。
  104. 如果没有指定 <code>$locale</code> ,那么当前对象的地方用于解释 <code>$date</code>,或选择本地化的格式来输出。
  105. </para>
  106. <para>
  107. 从 Zend Framework 1.7.0 开始,<code>Zend_Date</code> 也支持程序范围的地方的用法。你可以简单地如下设置 <code>Zend_Locale</code> 实例到注册表。
  108. 如果你想多次使用同一地方,用这个符号你不需要记住对每个实例手工设置地方。
  109. </para>
  110. <programlisting role="php"><![CDATA[
  111. // in your bootstrap file
  112. $locale = new Zend_Locale('de_AT');
  113. Zend_Registry::set('Zend_Locale', $locale);
  114. // somewhere in your application
  115. $date = new Zend_Date('31.Feb.2007');
  116. ]]>
  117. </programlisting>
  118. </sect2>
  119. <sect2 id="id.date.basic">
  120. <title>Basic <code>Zend_Date</code> Operations Common to Many Date Parts</title>
  121. <para>
  122. <code>add(), sub(), compare(), get(), and set()</code> 方法一般用来操作日期,就是操作对象里的日期。
  123. 除了 <code>get()</code>以外,<code>$date</code> 操作数对所有这些方法是必需的,它可能是 <code>Zend_Date</code> 实例对象、数字字符串或一个整数。
  124. 如果 <code>$date</code> 不是对象,这些方法就假定它是时间戳。然而,<code>$part</code> 操作数控制两个日期的逻辑部分,允许操作对象的日期的部件,如年或分钟,
  125. 即使 <code>$date</code> 包含一个长格式日期字符串,如 "December 31, 2007 23:59:59" 。
  126. 除了 <code>compare()</code> 和 <code>get()</code> 外,操作的结果是在对象里修改日期。
  127. </para>
  128. <example id="zend.date.basic.example-1">
  129. <title> 日期部件的操作 </title>
  130. <programlisting role="php"><![CDATA[
  131. $date = new Zend_Date(); // $date's timestamp === time()
  132. // changes $date by adding 12 hours
  133. $date->add('12', Zend_Date::HOUR);
  134. print $date;
  135. ]]>
  136. </programlisting>
  137. </example>
  138. <para>
  139. 下表显示了基本操作的每个组合和若干普通的日期部件的方便方法。当使用上述一般的方法时,这些方便的方法帮助我们懒惰的程序员避免在<link linkend="zend.date.constants.list"> 日期部件常量 </link> 方面的打字。
  140. 方便地,它们的名称由前缀(基本操作名)和后缀(日期部件类型)的组成,如 <code>addYear()</code> 。
  141. 在下面列表中,能看到所有“日期部件”和“基本操作”的组合。例如,"add"操作适用于这些日期部件,包括 <code>addDay()</code>、 <code>addYear()</code> 等。
  142. </para>
  143. <para>
  144. 这些方便的方法和基本操作方法有相同的功能,但期望字符串和整数的 <code>$date</code> 操作数只包含表示由方便方法的后缀指示的类型的值。
  145. 这样,当<code>$date</code>是字符串或整数时, 这些方法的名字(如"Year" 或 "Minute")能确定 <code>$date</code> 操作数的单元。
  146. </para>
  147. <sect3 id="id.date.basic.parts">
  148. <title> 日期部件列表 </title>
  149. <table id="id.date.basic.parts.table">
  150. <title>日期部件</title>
  151. <tgroup cols="2">
  152. <thead>
  153. <row>
  154. <entry>日期部件</entry>
  155. <entry>解释</entry>
  156. </row>
  157. </thead>
  158. <tbody>
  159. <row>
  160. <entry>
  161. <ulink url="http://en.wikipedia.org/wiki/Unix_Time">时间戳</ulink>
  162. </entry>
  163. <entry>
  164. UNIX 时间戳,表示从 January 1st, 1970 00:00:00 GMT/UTC 开始的秒数。
  165. </entry>
  166. </row>
  167. <row>
  168. <entry>
  169. <ulink url="http://en.wikipedia.org/wiki/Gregorian_calendar">年</ulink>
  170. </entry>
  171. <entry> 罗马教皇日历年(如 2006)</entry>
  172. </row>
  173. <row>
  174. <entry>
  175. <ulink url="http://en.wikipedia.org/wiki/Month#Julian_and_Gregorian_calendars">月</ulink>
  176. </entry>
  177. <entry> 罗马教皇日历月(1-12, 支持本地化名字)</entry>
  178. </row>
  179. <row>
  180. <entry>
  181. <ulink url="http://en.wikipedia.org/wiki/24-hour_clock">24 小时时钟 </ulink>
  182. </entry>
  183. <entry>一天的小时数(0-23),表示从一天开始算起过去的小时数。</entry>
  184. </row>
  185. <row>
  186. <entry>
  187. <ulink url="http://en.wikipedia.org/wiki/Minute">分钟</ulink>
  188. </entry>
  189. <entry>一小时的分钟数(0-59),表示从一小时开始算起过去的分钟数。</entry>
  190. </row>
  191. <row>
  192. <entry>
  193. <ulink url="http://en.wikipedia.org/wiki/Second">秒</ulink>
  194. </entry>
  195. <entry>一分钟的秒数(0-59),表示从一分钟开始算起过去的秒数。</entry>
  196. </row>
  197. <row>
  198. <entry>
  199. <ulink url="http://en.wikipedia.org/wiki/Millisecond">毫秒</ulink>
  200. </entry>
  201. <entry>
  202. 毫秒表示千分之一秒(0-999)。<code>Zend_Date</code> 支持两个另外的方法来支持小于秒的时间单位。
  203. 缺省地,<code>Zend_Date</code> 实例精确到毫秒,如 <code>getFractionalPrecision()</code> ,我们用 <code>setFractionalPrecision($precision)</code> 来修改精确度。
  204. 然而,因为 <code>Zend_Date</code> 使用 <code><ulink url="http://php.net/microtime">microtime()</ulink></code>,精确度实际上限制到微秒。
  205. </entry>
  206. </row>
  207. <row>
  208. <entry>
  209. <ulink url="http://en.wikipedia.org/wiki/Day">天</ulink>
  210. </entry>
  211. <entry>
  212. 如果 <code>$date</code> 操作数是 <code>Zend_Date</code> 的实例或一个数字字符串,<code>Zend_Date::DAY_SHORT</code> 是从 <code>$date</code> 里取出。
  213. 否则,根据这些文档 <code>Zend_Date::WEEKDAY_NARROW</code>、
  214. <code>Zend_Date::WEEKDAY_NAME</code>、 <code>Zend_Date::WEEKDAY_SHORT</code> 和 <code>Zend_Date::WEEKDAY</code> (假定为罗马教皇日历)的惯例尝试从天里取出。
  215. </entry>
  216. </row>
  217. <row>
  218. <entry>
  219. <ulink url="http://en.wikipedia.org/wiki/Week">星期</ulink>
  220. </entry>
  221. <entry>
  222. 如果 <code>$date</code> 操作数是 <code>Zend_Date</code> 的实例或一个数字字符串,<code>Zend_Date::WEEK</code> 是从 <code>$date</code> 里取出。
  223. 否则产生一个异常。(假定为罗马教皇日历)
  224. </entry>
  225. </row>
  226. <row>
  227. <entry>日期</entry>
  228. <entry>
  229. 如果 <code>$date</code> 操作数是 <code>Zend_Date</code> 的实例或一个数字字符串,<code>Zend_Date::DAY_MEDIUM</code> 是从 <code>$date</code> 里取出。
  230. 否则就尝试格式化 <code>$date</code> 字符串成 Zend_Date::DATE_MEDIUM 日期格式。
  231. <code>Zend_Date::DAY_MEDIUM</code> 格式根据地方的不同而不同。
  232. </entry>
  233. </row>
  234. <row>
  235. <entry>Weekday</entry>
  236. <entry>
  237. Weekdays 表示为从 0 (星期日) 到 6 (星期六).
  238. 如果 <code>$date</code> 操作数是 <code>Zend_Date</code> 的实例或一个数字字符串,<code>Zend_Date::WEEKDAY_DIGIT</code> 是从 <code>$date</code> 里取出。
  239. 否则,根据这些文档 <code>Zend_Date::WEEKDAY_NARROW</code>、
  240. <code>Zend_Date::WEEKDAY_NAME</code>、 <code>Zend_Date::WEEKDAY_SHORT</code> 和 <code>Zend_Date::WEEKDAY</code> (假定为罗马教皇日历)的惯例尝试从天里取出。
  241. </entry>
  242. </row>
  243. <row>
  244. <entry>DayOfYear</entry>
  245. <entry>
  246. 在 <code>Zend_Date</code>,一年中的天表示从一年开始发生的日历天数(0-365)。和其它上述单元一样,小数四舍五入到最近的整数。(假定为罗马教皇日历)
  247. </entry>
  248. </row>
  249. <row>
  250. <entry>
  251. <ulink url="http://www.faqs.org/rfcs/rfc822.html">Arpa</ulink>
  252. </entry>
  253. <entry>
  254. 我们支持 Arpa 日期(如 RFC 822 格式日期)。输出使用 "GMT" 或 "Local differential hours+min" 格式(见第5节的 RFC 822)。
  255. 在 PHP 5.2.2 以前,一起使用 DATE_RFC822 常量和 PHP 日期函数有时会产生 <ulink url="http://bugs.php.net/bug.php?id=40308">不正确的结果</ulink>。
  256. Zend_Date 的结果是正确的。例如 <code>Mon, 31 Dec 06 23:59:59 GMT</code> 。
  257. </entry>
  258. </row>
  259. <row>
  260. <entry>
  261. <ulink url="http://en.wikipedia.org/wiki/ISO_8601">Iso</ulink>
  262. </entry>
  263. <entry>
  264. 对于输出只支持完全的 ISO 8601 日期。例如:<code>2009-02-14T00:31:30+01:00</code>
  265. </entry>
  266. </row>
  267. </tbody>
  268. </tgroup>
  269. </table>
  270. </sect3>
  271. <sect3 id="id.date.basic.operations">
  272. <title>List of Date Operations 日期操作列表</title>
  273. <para>
  274. 如果 <link linkend="zend.date.constants.list"> 合适的常量 </link> 用于 <code>$part</code> 参数,
  275. 对特定日期部件,下列基本操作可用来代替方便操作。
  276. </para>
  277. <table id="id.date.basic.operations.table">
  278. <title>基本操作</title>
  279. <tgroup cols="2">
  280. <thead>
  281. <row>
  282. <entry>基本操作</entry>
  283. <entry>解释</entry>
  284. </row>
  285. </thead>
  286. <tbody>
  287. <row>
  288. <entry>get()</entry>
  289. <entry>
  290. <para>
  291. <emphasis role="strong">get($part = null, $locale = null)</emphasis>
  292. </para>
  293. <para>
  294. 使用 <code>get($part)</code> 来获取这个对象的本地化到 <code>$locale</code> 为格式的字符串或整数的日期的 <code>$part</code> 。
  295. 当使用 BCMath 扩展,对大的值返回数字字符串而不是整数。
  296. <emphasis role="strong">注:</emphasis> 不像 <code>get()</code>,其它 get*() 方便方法只返回 <code>Zend_Date</code> 的实例,
  297. 该实例包含一个表示选择的或计算的日期/时间的日期。
  298. </para>
  299. </entry>
  300. </row>
  301. <row>
  302. <entry>set()</entry>
  303. <entry>
  304. <para>
  305. <emphasis role="strong">set($date, $part = null, $locale = null)</emphasis>
  306. </para>
  307. <para>
  308. 对从带有 <code>$locale</code> 地方的输入 <code>$date</code> 找到的部件设置当前对象的 <code>$part</code> 一个相应的值。
  309. </para>
  310. </entry>
  311. </row>
  312. <row>
  313. <entry>add()</entry>
  314. <entry>
  315. <para>
  316. <emphasis role="strong">add($date, $part = null, $locale = null)</emphasis>
  317. </para>
  318. <para>
  319. 加上带有 <code>$locale</code> 地方的 <code>$date</code> 的 <code>$part</code> 到当前对象的日期。
  320. </para>
  321. </entry>
  322. </row>
  323. <row>
  324. <entry>sub()</entry>
  325. <entry>
  326. <para>
  327. <emphasis role="strong">sub($date, $part = null, $locale = null)</emphasis>
  328. </para>
  329. <para>
  330. 从当前对象的日期减去 加上带有 <code>$locale</code> 地方的 <code>$date</code> 的 <code>$part</code> 。
  331. </para>
  332. </entry>
  333. </row>
  334. <row>
  335. <entry>copyPart()</entry>
  336. <entry>
  337. <para>
  338. <emphasis role="strong">copyPart($part, $locale = null)</emphasis>
  339. </para>
  340. <para>
  341. 返回一个克隆的对象,只带有拷贝到克隆的对象的日期的 <code>$part</code> ,克隆带有它自己的地方任意地设置为 <code>$locale</code> (如果指定)。
  342. </para>
  343. </entry>
  344. </row>
  345. <row>
  346. <entry>compare()</entry>
  347. <entry>
  348. <para>
  349. <emphasis role="strong">compare($date, $part = null, $locale = null)</emphasis>
  350. </para>
  351. <para>
  352. 比较 <code>$date</code> 的 <code>$part</code> 和这个对象的时间戳,如果相等返回 0,如果对象部分更晚,返回1,否则返回 -1。
  353. </para>
  354. </entry>
  355. </row>
  356. </tbody>
  357. </tgroup>
  358. </table>
  359. </sect3>
  360. </sect2>
  361. <sect2 id="zend.date.others.comparison">
  362. <title> 比较日期 </title>
  363. <para>
  364. 对于列表在 <xref linkend="zend.date.overview" />的日期部件,下列基本操作没有相应的方便方法。
  365. </para>
  366. <table id="zend.date.others.comparison.table">
  367. <title> 日期比较方法 </title>
  368. <tgroup cols="2">
  369. <thead>
  370. <row>
  371. <entry>方法</entry>
  372. <entry>解释</entry>
  373. </row>
  374. </thead>
  375. <tbody>
  376. <row>
  377. <entry>equals()</entry>
  378. <entry>
  379. <para>
  380. <emphasis role="strong">equals($date, $part = null, $locale = null)</emphasis>
  381. </para>
  382. <para>
  383. 如果有 <code>$locale</code> 地方的 <code>$date</code> 的 <code>$part</code> 和这个对象的 <code>$part</code> 一样,返回 true,否则返回 false。
  384. </para>
  385. </entry>
  386. </row>
  387. <row>
  388. <entry>isEarlier()</entry>
  389. <entry>
  390. <para>
  391. <emphasis role="strong">isEarlier($date, $part = null, $locale = null)</emphasis>
  392. </para>
  393. <para>
  394. 如果对象的日期的 <code>$part</code> 早于 有 <code>$locale</code> 地方的 <code>$date</code> 的 <code>$part</code> ,返回 true。
  395. </para>
  396. </entry>
  397. </row>
  398. <row>
  399. <entry>isLater()</entry>
  400. <entry>
  401. <para>
  402. <emphasis role="strong">isLater($date, $part = null, $locale = null)</emphasis>
  403. </para>
  404. <para>
  405. 如果对象的日期的 <code>$part</code> 晚于有 <code>$locale</code> 地方的 <code>$date</code> 的 <code>$part</code> ,返回 true。
  406. </para>
  407. </entry>
  408. </row>
  409. <row>
  410. <entry>isToday()</entry>
  411. <entry>
  412. <para>
  413. <emphasis role="strong">isToday()</emphasis>
  414. </para>
  415. <para>
  416. 测试是否今天的年、月、日匹配这个对象的日期值,使用对象的时区。
  417. </para>
  418. </entry>
  419. </row>
  420. <row>
  421. <entry>isTomorrow()</entry>
  422. <entry>
  423. <para>
  424. <emphasis role="strong">isTomorrow()</emphasis>
  425. </para>
  426. <para>
  427. 测试是否明天的年、月、日匹配这个对象的日期值,使用对象的时区。
  428. </para>
  429. </entry>
  430. </row>
  431. <row>
  432. <entry>isYesterday()</entry>
  433. <entry>
  434. <para>
  435. <emphasis role="strong">isYesterday()</emphasis>
  436. </para>
  437. <para>
  438. 测试是否昨天的年、月、日匹配这个对象的日期值,使用对象的时区。
  439. </para>
  440. </entry>
  441. </row>
  442. <row>
  443. <entry>isLeapYear()</entry>
  444. <entry>
  445. <para>
  446. <emphasis role="strong">isLeapYear()</emphasis>
  447. </para>
  448. <para>
  449. 使用 <code>isLeapYear()</code> 来确定当前对象是否闰年,或使用 Zend_Date::checkLeapYear($year) 来
  450. 检查 $year,它可以是字符串、整数或 <code>Zend_Date</code> 的实例。这个年是闰年吗?
  451. </para>
  452. </entry>
  453. </row>
  454. <row>
  455. <entry>isDate()</entry>
  456. <entry>
  457. <para>
  458. <emphasis role="strong">isDate($date, $format = null, $locale = null)</emphasis>
  459. </para>
  460. <para>
  461. 这个方法检查给定的日期是否一个真实的日期并且如果所有检查通过返回 true。
  462. 它和 php 的 checkdate() 函数一样但也检查本地化月名和扩展了 checkdate() 范围的日期。
  463. </para>
  464. </entry>
  465. </row>
  466. </tbody>
  467. </tgroup>
  468. </table>
  469. </sect2>
  470. <sect2 id="zend.date.others.gettingparts">
  471. <title>获取日期和日期部件</title>
  472. <para>
  473. 有若干方法支持获取和 <code>Zend_Date</code> 实例相关的值。
  474. </para>
  475. <table id="zend.date.others.gettingparts.table">
  476. <title>日期输出方法</title>
  477. <tgroup cols="2">
  478. <thead>
  479. <row>
  480. <entry>方法</entry>
  481. <entry>解释</entry>
  482. </row>
  483. </thead>
  484. <tbody>
  485. <row>
  486. <entry>toString()</entry>
  487. <entry>
  488. <para>
  489. <emphasis role="strong">toString($format = null, $locale = null)</emphasis>
  490. </para>
  491. <para>
  492. 直接调用或通过魔术方法 <code>__toString()</code> 。<code>toString()</code> 根据对象地方(或可选地指定 <code>$locale</code>)的约定
  493. 来自动格式化日期对象的值。支持的格式代码列表,参见 <xref linkend="zend.date.constants.selfdefinedformats" /> 。
  494. </para>
  495. </entry>
  496. </row>
  497. <row>
  498. <entry>toArray()</entry>
  499. <entry>
  500. <para>
  501. <emphasis role="strong">toArray()</emphasis>
  502. </para>
  503. <para>
  504. 根据对象的地方的约定返回选择的日期的表示的数组。返回数组和 PHP 的 <ulink url="http://php.net/getdate">getdate()</ulink>
  505. 函数相同并包括:
  506. </para>
  507. <para>
  508. <itemizedlist>
  509. <listitem>
  510. <para>
  511. Number of day as '<emphasis role="strong">day</emphasis>'
  512. (<code>Zend_Date::DAY_SHORT</code>)
  513. </para>
  514. </listitem>
  515. <listitem>
  516. <para>
  517. Number of month as '<emphasis role="strong">month</emphasis>'
  518. (<code>Zend_Date::MONTH_SHORT</code>)
  519. </para>
  520. </listitem>
  521. <listitem>
  522. <para>
  523. Year as '<emphasis role="strong">year</emphasis>'
  524. (<code>Zend_Date::YEAR</code>)
  525. </para>
  526. </listitem>
  527. <listitem>
  528. <para>
  529. Hour as '<emphasis role="strong">hour</emphasis>'
  530. (<code>Zend_Date::HOUR_SHORT</code>)
  531. </para>
  532. </listitem>
  533. <listitem>
  534. <para>
  535. Minute as '<emphasis role="strong">minute</emphasis>'
  536. (<code>Zend_Date::MINUTE_SHORT</code>)
  537. </para>
  538. </listitem>
  539. <listitem>
  540. <para>
  541. Second as '<emphasis role="strong">second</emphasis>'
  542. (<code>Zend_Date::SECOND_SHORT</code>)
  543. </para>
  544. </listitem>
  545. <listitem>
  546. <para>
  547. Abbreviated timezone as '<emphasis role="strong">timezone</emphasis>'
  548. (<code>Zend_Date::TIMEZONE</code>)
  549. </para>
  550. </listitem>
  551. <listitem>
  552. <para>
  553. Unix timestamp as '<emphasis role="strong">timestamp</emphasis>'
  554. (<code>Zend_Date::TIMESTAMP</code>)
  555. </para>
  556. </listitem>
  557. <listitem>
  558. <para>
  559. Number of weekday as '<emphasis role="strong">weekday</emphasis>'
  560. (<code>Zend_Date::WEEKDAY_DIGIT</code>)
  561. </para>
  562. </listitem>
  563. <listitem>
  564. <para>
  565. Day of year as '<emphasis role="strong">dayofyear</emphasis>'
  566. (<code>Zend_Date::DAY_OF_YEAR</code>)
  567. </para>
  568. </listitem>
  569. <listitem>
  570. <para>
  571. Week as '<emphasis role="strong">week</emphasis>'
  572. (<code>Zend_Date::WEEK</code>)
  573. </para>
  574. </listitem>
  575. <listitem>
  576. <para>
  577. Delay of timezone to GMT as
  578. '<emphasis role="strong">gmtsecs</emphasis>'
  579. (<code>Zend_Date::GMT_SECS</code>)
  580. </para>
  581. </listitem>
  582. </itemizedlist>
  583. </para>
  584. </entry>
  585. </row>
  586. <row>
  587. <entry>toValue()</entry>
  588. <entry>
  589. <para>
  590. <emphasis role="strong">toValue($part = null)</emphasis>
  591. </para>
  592. <para>
  593. 根据对象的地方的约定返回一个整数的选择的日期 <code>$part</code> 表示。
  594. 当 <code>$part</code>选择非数字值,如 <code>Zend_Date::MONTH_NAME_SHORT</code> ,返回 <code>false</code>。
  595. <emphasis role="strong">注:</emphasis>这个方法调用 <link linkend="id.date.basic.operations"><code>get()</code></link>
  596. 并把结果做成 PHP 整数,如果 <code>get()</code> 返回一个包含对于你的系统的PHP太大的数的字符串,结果不可预计。
  597. 使用 <code>get()</code> 作为替换。
  598. </para>
  599. </entry>
  600. </row>
  601. <row>
  602. <entry>
  603. <link linkend="id.date.basic.operations">get()</link>
  604. </entry>
  605. <entry>
  606. <para>
  607. <emphasis role="strong">get($part = null, $locale = null)</emphasis>
  608. </para>
  609. <para>
  610. 这个方法返回对象根据 <code>$locale</code> 本地化的日期的 <code>$part</code>,格式为字符串或整数。
  611. 更多信息参见<xref linkend="id.date.basic.operations" />。
  612. </para>
  613. </entry>
  614. </row>
  615. <row>
  616. <entry>now()</entry>
  617. <entry>
  618. <para>
  619. <emphasis role="strong">now($locale = null)</emphasis>
  620. </para>
  621. <para>
  622. 这个方便函数和 <code>new Zend_Date()</code> 相同。它以<code>Zend_Date</code>对象返回当前日期,有 <code>$locale</code> 。
  623. </para>
  624. </entry>
  625. </row>
  626. </tbody>
  627. </tgroup>
  628. </table>
  629. </sect2>
  630. <sect2 id="zend.date.others.fractions">
  631. <title> 使用秒的片段 </title>
  632. <para>
  633. Several methods support retrieving values related to a <code>Zend_Date</code> instance.
  634. </para>
  635. <table id="zend.date.others.fractions.table">
  636. <title> 日期输出方法 </title>
  637. <tgroup cols="2">
  638. <thead>
  639. <row>
  640. <entry>方法</entry>
  641. <entry>解释</entry>
  642. </row>
  643. </thead>
  644. <tbody>
  645. <row>
  646. <entry>
  647. <para>
  648. <emphasis role="strong">getFractionalPrecision()</emphasis>
  649. </para>
  650. </entry>
  651. <entry> 返回秒的精度 </entry>
  652. </row>
  653. <row>
  654. <entry>
  655. <para>
  656. <emphasis role="strong">setFractionalPrecision()</emphasis>
  657. </para>
  658. </entry>
  659. <entry> 设置秒的精度 </entry>
  660. </row>
  661. </tbody>
  662. </tgroup>
  663. </table>
  664. </sect2>
  665. <sect2 id="zend.date.other.sun">
  666. <title> 日出 / 日落 </title>
  667. <para>
  668. 有三个方法提供访问关于太阳的地理本地化信息,包括日出和日落的时间。
  669. </para>
  670. <table id="zend.date.other.sun.table">
  671. <title> 辅助方法 </title>
  672. <tgroup cols="2">
  673. <thead>
  674. <row>
  675. <entry>方法</entry>
  676. <entry>解释</entry>
  677. </row>
  678. </thead>
  679. <tbody>
  680. <row>
  681. <entry>
  682. <para>
  683. <emphasis role="strong">getSunrise($location)</emphasis>
  684. </para>
  685. </entry>
  686. <entry> 返回日期的日出时间 </entry>
  687. </row>
  688. <row>
  689. <entry>
  690. <para>
  691. <emphasis role="strong">getSunset($location)</emphasis>
  692. </para>
  693. </entry>
  694. <entry> 返回日期的日落时间 </entry>
  695. </row>
  696. <row>
  697. <entry>
  698. <para>
  699. <emphasis role="strong">getSunInfo($location)</emphasis>
  700. </para>
  701. </entry>
  702. <entry> 返回带有日期的太阳日期的数组 </entry>
  703. </row>
  704. </tbody>
  705. </tgroup>
  706. </table>
  707. </sect2>
  708. </sect1>
  709. <!--
  710. vim:se ts=4 sw=4 et:
  711. -->