File: Zend_Date-Introduction.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (144 lines) | stat: -rw-r--r-- 7,586 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
<?xml version="1.0" encoding="utf-8"?>
<!-- EN-Revision: 24249 -->
<!-- Reviewed: no -->
<sect1 id="zend.date.introduction">
    <title>Introduction</title>

    <para>
        Le composant <classname>Zend_Date</classname> fournit une <acronym>API</acronym> simple de manipulation
        des dates et des temps. Ses méthodes acceptent un grand nombre de paramètres formatés,
        comme des parties de dates, et complètent bien le support natif des dates de <acronym>PHP</acronym>.
    </para>

    <para>
        Même si rester simple est un objectif, manipuler des dates et des temps localisés,
        les additionner, par parties, les convertir ... mène vers une certaine complexité
        inévitable. Les dates et les temps sont souvent notés de manière très différente selon la
        locale. Par exemple, certaines locales placent le mois en premier, d'autres l'année. Pour
        plus d'information sur la gestion de la localisation et de la normalisation, voyez le
        manuel de
        <link linkend="zend.locale.date.datesandtimes"><classname>Zend_Locale</classname></link>.
    </para>

    <para>
        <classname>Zend_Date</classname> supporte aussi les noms abrégés des mois dans
        beaucoup de langues.<classname>Zend_Locale</classname> facilite la localisation et la
        normalisation des mois localisés et des jours de semaines, leur conversion vers des
        timestamps.
    </para>

    <sect2 id="zend.date.setdefaulttimezone">
        <title>Définissez toujours un fuseau horaire par défaut</title>

        <para>
            Avant toute manipulation de date, que ce soit par les fonctions PHP, ou par Zend
            Framework, soyez sûrs que votre fuseau horaire par défaut est défini. Configurez votre
            variable d'environnement TZ, <code>date.timezone</code> dans le php.ini, ou utilisez
            <ulink url="http://php.net/date_default_timezone_set">
            date_default_timezone_set()</ulink>. En PHP nous pouvons ajuster les fonctions de date
            et temps pour fonctionner selon un certain fuseau horaire. Pour les options et la liste
            des fuseaux, consultez
            <ulink url="http://unicode.org/cldr/data/diff/supplemental/territory_containment_un_m_49.html">
            La liste des identifiants de fuseaux horaires</ulink>.
            <example id="zend.date.setdefaulttimezone.example-1">
                <title>Spécifier un fuseau par défaut </title>

                <programlisting language="php"><![CDATA[
// timezone pour un américain en Californie
date_default_timezone_set('America/Los_Angeles');
// timezone pour un allemand en Allemagne
date_default_timezone_set('Europe/Berlin');
]]></programlisting>
            </example>
            <emphasis>Lorsque vous créez des instances de Zend_Date, leur
            fuseau sera automatiquement mis à celui par défaut&#160;!</emphasis> Ainsi, le
            paramètre de fuseau horaire prendre en compte le DST si besoin, vous n'aurez donc pas
            besoin de leconfigurer.
        </para>

        <para>
            Souvenez vous que les fuseaux <emphasis>UTC</emphasis> et <emphasis>GMT</emphasis>
            n'incluent pas la notion "d'heure d'hiver"(Daylight Saving
            Time, <acronym>DST</acronym>). Donc même si vous dites à <classname>Zend_Date</classname> de prendre en
            compte le <acronym>DST</acronym>, il sera annulé pour les futures instances de
            <classname>Zend_Date</classname> utilisant <acronym>UTC</acronym> ou <acronym>GMT</acronym>.
        </para>
    </sect2>

    <sect2 id="zend.date.why">
        <title>Pourquoi utiliser Zend_Date&#160;?</title>

        <para>
            <classname>Zend_Date</classname> a les caractéristiques suivantes, qui étendent
            et complètent les fonctions de date de <acronym>PHP</acronym>&#160;:
        </para>

        <itemizedlist mark="opencircle">
            <listitem>
                <para>API simple</para>

                <para>
                    <classname>Zend_Date</classname> propose une <acronym>API</acronym> simple, qui combine les
                    meilleures fonctionnalités depuis 4 langages de programmation. Il est par
                    exemple possible de comparer ou ajouter 2 dates.
                </para>
            </listitem>

            <listitem>
                <para>Internationalisé</para>

                <para>
                    Toutes les abréviations des noms des mois ou des jours sont traduits dans
                    plus de 130 langues. Les méthodes supportent des entrées et sorties de dates
                    utilisant ces noms localisés.
                </para>
            </listitem>

            <listitem>
                <para>Timestamps infinis</para>

                <para>
                    La documentation de <acronym>PHP</acronym> 5.2 indique, "L'intervalle de validité des
                    timestamps est du 13 Dec 1901 20:45:54 <acronym>GMT</acronym> au 19 Jan 2038 03:14:07 <acronym>GMT</acronym>",
                    <classname>Zend_Date</classname> supporte un intervalle quasi illimité grâce à
                    l'extension BCMath. Si l'extension BCMath n'est pas disponible, alors le
                    support des timestamp sera réduit à la valeur maximale du type <acronym>PHP</acronym>
                    <code>float</code> supporté par le serveur. "La taille du float est dépendant
                    de la plate-forme, un maximum de ~1.8e308 avec une précision d'environ 14
                    décimales est une valeur connue (64 bit IEEE format)." [
                    <ulink url="http://www.php.net/float">http://www.php.net/float</ulink>]. Aussi,
                    des limitations dans le calcul des flottants, comme des arrondis non
                    désirables, peuvent apparaître. Ces problèmes sont évités grâce à l'extension
                    BCMath, si disponible.
                </para>
            </listitem>

            <listitem>
                <para>Support des dates ISO_8601</para>

                <para>
                    Le support complet de ISO_8601 est pris en charge. Même les données
                    partiellement ISO_8601 seront identifiées correctement. Ces formats sont utiles
                    pour le travail avec des bases de données. Par exemple MSSQL et
                    <ulink url="http://dev.mysql.com/doc/refman/5.0/en/date-and-time-functions.html">
                    MySQL</ulink>les utilise mais diffèrent légèrement dans leur format, cependant
                    ils sont supportés par <classname>Zend_Date</classname> grâce à la constante de
                    spécification de format
                    <link linkend="zend.date.constants.list">Zend_Date::ISO_8601</link>. Si les
                    chaînes des dates sont conformes à "Y/m/d" ou "Y-m-d H:i:s", selon les formats
                    de <methodname>date()</methodname> de <acronym>PHP</acronym>, utilisez le support de
                    <classname>Zend_Date</classname> pour le format <acronym>ISO</acronym> 8601.
                </para>
            </listitem>

            <listitem>
                <para>Calculer le sunrise et sunset</para>

                <para>
                    N'importe où dans la journée, les temps du sunrise (levé de soleil) et
                    sunset (couché de soleil) peuvent être affichés.
                </para>
            </listitem>
        </itemizedlist>
    </sect2>
</sect1>