Zend_View-Helpers-Translate.xml 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201
  1. <!-- EN-Revision: 13826 -->
  2. <sect3 id="zend.view.helpers.initial.translate">
  3. <title>L'aide de vue Translate</title>
  4. <para>Souvent le sites Web sont disponibles en plusieurs langues. Pour traduire le contenu d'un site, vous pouvez
  5. simplement utiliser <link linkend="zend.translate.introduction">Zend Translate</link> et pour intégrer <code>Zend
  6. Translate</code> à l'intérieur de vos vues, vous devriez utiliser l'aide de vue <code>Translate</code>.</para>
  7. <para>Dans tous les exemples suivants nous allons utiliser l'adaptateur de traduction <code>Array</code>. Bien sûr
  8. vous pouvez aussi utiliser toute instance de <classname>Zend_Translate</classname> ainsi que toutes sous-classes de
  9. <classname>Zend_Translate_Adapter</classname>. Il y a plusieurs manières d'initialiser l'aide de vue <code>Translate</code>
  10. :</para>
  11. <itemizedlist>
  12. <listitem>
  13. <para>enregistré préalablement dans <classname>Zend_Registry</classname></para>
  14. </listitem>
  15. <listitem>
  16. <para>après, par l'interface fluide</para>
  17. </listitem>
  18. <listitem>
  19. <para>directement en initialisant la classe</para>
  20. </listitem>
  21. </itemizedlist>
  22. <para>Une instance préalablement enregistré de <classname>Zend_Translate</classname> est l'utilisation préférée pour cette
  23. aide. Vous pouvez ainsi sélectionner la locale à utiliser avant d'ajouter l'adaptateur dans le registre.</para>
  24. <note>
  25. <para>Nous parlons de locales et non de langues car une langue peut aussi contenir une région. Par exemple
  26. l'anglais est parlé en différents dialectes. Il peut y avoir une traduction pour l'anglais et une pour
  27. l'américain. Ainsi, nous disons "locale" plutôt que "langues".</para>
  28. </note>
  29. <example id="zend.view.helpers.initial.translate.registered">
  30. <title>Instance enregistrée</title>
  31. <para>Pour utiliser une instance enregistrée, créez une instance de <classname>Zend_Translate</classname> ou
  32. <classname>Zend_Translate_Adapter</classname> et enregistrez la dans <classname>Zend_Registry</classname> en utilisant la clé
  33. <classname>Zend_Translate</classname>.</para>
  34. <programlisting role="php"><![CDATA[
  35. // notre adaptateur d'exemple
  36. $adapter = new Zend_Translate('array', array('simple' => 'einfach'), 'de');
  37. Zend_Registry::set('Zend_Translate', $adapter);
  38. // à l'intérieur de votre vue
  39. echo $this->translate('simple');
  40. // ceci retourne 'einfach'
  41. ]]></programlisting>
  42. </example>
  43. <para>Si vous êtes plus familier avec l'interface fluide, alors vous pouvez aussi créer une instance à l'intérieur
  44. de votre vue et initialiser l'aide ensuite.</para>
  45. <example id="zend.view.helpers.initial.translate.afterwards">
  46. <title>A l'intérieur de la vue</title>
  47. <para>Pour utiliser l'interface fluide, créez une instance de <classname>Zend_Translate</classname> ou
  48. <classname>Zend_Translate_Adapter</classname>, appelez l'aide sans paramètres, et appelez la méthode
  49. <code>setTranslator()</code>.</para>
  50. <programlisting role="php"><![CDATA[
  51. // à l'intérieur de votre vue
  52. $adapter = new Zend_Translate('array', array('simple' => 'einfach'), 'de');
  53. $this->translate()->setTranslator($adapter)->translate('simple');
  54. // ceci retourne 'einfach'
  55. ]]></programlisting>
  56. </example>
  57. <para>Si vous utilisez votre aide sans <classname>Zend_View</classname>, alors vous pouvez aussi l'utiliser
  58. directement.</para>
  59. <example id="zend.view.helpers.initial.translate.directly">
  60. <title>Utilisation directe</title>
  61. <programlisting role="php"><![CDATA[
  62. // notre adaptateur d'exemple
  63. $adapter = new Zend_Translate('array', array('simple' => 'einfach'), 'de');
  64. // initialiser l'adaptateur
  65. $translate = new Zend_View_Helper_Translate($adapter);
  66. print $translate->translate('simple');
  67. // ceci retourne 'einfach'
  68. ]]></programlisting>
  69. <para>Vous devriez utiliser cette façon de faire si vous ne travaillez pas avec <classname>Zend_View</classname> et que
  70. vous avez besoin de créer des affichages traduits.</para>
  71. </example>
  72. <para>Comme vu auparavant, la méthode <code>translate()</code> est utilisé pour retourner la traduction. Appelez la
  73. simplement avec l'identifiant de message de votre adaptateur de traduction. Mais il peut aussi avoir à remplacer des
  74. paramètres dans la chaîne de traduction. Donc, il accepte des paramètres de deux manières : soit comme une liste de
  75. paramètres, soit comme un tableau de paramètres. Par exemple :</para>
  76. <example id="zend.view.helpers.initial.translate.parameter">
  77. <title>Paramètres unique</title>
  78. <para>Pour utiliser un paramètre unique, ajoutez le en fin de méthode :</para>
  79. <programlisting role="php"><![CDATA[
  80. // à l'intérieur de votre vue
  81. $date = "Monday";
  82. $this->translate("Today is %1\$s", $date);
  83. // ceci retourne 'Heute ist Monday'
  84. ]]></programlisting>
  85. </example>
  86. <note>
  87. <para>Gardez à l'esprit que si vous utilisez des paramètres qui sont aussi des textes, vous pouvez aussi avoir à
  88. traduire ces paramètres.</para>
  89. </note>
  90. <example id="zend.view.helpers.initial.translate.parameterlist">
  91. <title>Liste de paramètres</title>
  92. <para>Ou utiliser une liste de paramètres et ajoutez les en fin de méthode :</para>
  93. <programlisting role="php"><![CDATA[
  94. // à l'intérieur de votre vue
  95. $date = "Monday";
  96. $month = "April";
  97. $time = "11:20:55";
  98. $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s",
  99. $date,
  100. $month,
  101. $time);
  102. // ceci retourne 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55'
  103. ]]></programlisting>
  104. </example>
  105. <example id="zend.view.helpers.initial.translate.parameterarray">
  106. <title>Tableau de paramètres</title>
  107. <para>Ou utiliser un tableau de paramètres et ajoutez le en fin de méthode :</para>
  108. <programlisting role="php"><![CDATA[
  109. // à l'intérieur de votre vue
  110. $date = array("Monday", "April", "11:20:55");
  111. $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
  112. // Could return 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55'
  113. ]]></programlisting>
  114. </example>
  115. <para>Parfois il est nécessaire de changer la locale pour une traduction. Ceci peut être fait soit dynamiquement par
  116. traduction ou statiquement pour toutes les traductions suivantes. Et vous pouvez utiliser ceci avec une liste de
  117. paramètres ou un tableau de paramètres. Dans les deux cas la locale doit être fournie comme un paramètre unique
  118. final.</para>
  119. <example id="zend.view.helpers.initial.translate.dynamic">
  120. <title>Changement dynamique de la locale</title>
  121. <programlisting role="php"><![CDATA[
  122. // à l'intérieur de votre vue
  123. $date = array("Monday", "April", "11:20:55");
  124. $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date, 'it');
  125. ]]></programlisting>
  126. </example>
  127. <para>Cet exemple retourne la traduction italienne pour l'identifiant de message. Mais la locale ne sera utilisée
  128. qu'une seule fois. La traduction suivante utilisera la locale de l'adaptateur. Normalement vous réglerez la locale
  129. au niveau de votre adaptateur avant de le mettre dans le registre. Mais vous pouvez aussi paramétrer la locale avec
  130. l'aide de vue :</para>
  131. <example id="zend.view.helpers.initial.translate.static">
  132. <title>Changement statique de la locale</title>
  133. <programlisting role="php"><![CDATA[
  134. // à l'intérieur de votre vue
  135. $date = array("Monday", "April", "11:20:55");
  136. $this->translate()->setLocale('it');
  137. $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
  138. ]]></programlisting>
  139. </example>
  140. <para>L'exemple ci-dessus paramètre <code>'it'</code> comme nouvelle locale par défaut, elle sera utilisée pour
  141. toutes les traductions ultérieures.</para>
  142. <para>Bien sûr il existe aussi la méthode <code>getLocale()</code> pour récupérer le réglage courant de la
  143. locale.</para>
  144. <example id="zend.view.helpers.initial.translate.getlocale">
  145. <title>Récupération de la locale courante</title>
  146. <programlisting role="php"><![CDATA[
  147. // à l'intérieur de votre vue
  148. $date = array("Monday", "April", "11:20:55");
  149. // retourne 'de' comme réglé dans les exemples précédents
  150. $this->translate()->getLocale();
  151. $this->translate()->setLocale('it');
  152. $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
  153. // retourne 'it' comme nouvelle locale par défaut
  154. $this->translate()->getLocale();
  155. ]]></programlisting>
  156. </example>
  157. </sect3>