L'aide de vue TranslateSouvent le sites Web sont disponibles en plusieurs langues. Pour traduire le contenu d'un site, vous pouvez
simplement utiliser Zend Translate et pour intégrer Zend
Translate à l'intérieur de vos vues, vous devriez utiliser l'aide de vue Translate.Dans tous les exemples suivants nous allons utiliser l'adaptateur de traduction Array. Bien sûr
vous pouvez aussi utiliser toute instance de Zend_Translate ainsi que toutes sous-classes de
Zend_Translate_Adapter. Il y a plusieurs manières d'initialiser l'aide de vue Translate
:enregistré préalablement dans Zend_Registryaprès, par l'interface fluidedirectement en initialisant la classeUne instance préalablement enregistré de Zend_Translate est l'utilisation préférée pour cette
aide. Vous pouvez ainsi sélectionner la locale à utiliser avant d'ajouter l'adaptateur dans le registre.Nous parlons de locales et non de langues car une langue peut aussi contenir une région. Par exemple
l'anglais est parlé en différents dialectes. Il peut y avoir une traduction pour l'anglais et une pour
l'américain. Ainsi, nous disons "locale" plutôt que "langues".Instance enregistréePour utiliser une instance enregistrée, créez une instance de Zend_Translate ou
Zend_Translate_Adapter et enregistrez la dans Zend_Registry en utilisant la clé
Zend_Translate. 'einfach'), 'de');
Zend_Registry::set('Zend_Translate', $adapter);
// à l'intérieur de votre vue
echo $this->translate('simple');
// ceci retourne 'einfach'
]]>Si vous êtes plus familier avec l'interface fluide, alors vous pouvez aussi créer une instance à l'intérieur
de votre vue et initialiser l'aide ensuite.A l'intérieur de la vuePour utiliser l'interface fluide, créez une instance de Zend_Translate ou
Zend_Translate_Adapter, appelez l'aide sans paramètres, et appelez la méthode
setTranslator(). 'einfach'), 'de');
$this->translate()->setTranslator($adapter)->translate('simple');
// ceci retourne 'einfach'
]]>Si vous utilisez votre aide sans Zend_View, alors vous pouvez aussi l'utiliser
directement.Utilisation directe 'einfach'), 'de');
// initialiser l'adaptateur
$translate = new Zend_View_Helper_Translate($adapter);
print $translate->translate('simple');
// ceci retourne 'einfach'
]]>Vous devriez utiliser cette façon de faire si vous ne travaillez pas avec Zend_View et que
vous avez besoin de créer des affichages traduits.Comme vu auparavant, la méthode translate() est utilisé pour retourner la traduction. Appelez la
simplement avec l'identifiant de message de votre adaptateur de traduction. Mais il peut aussi avoir à remplacer des
paramètres dans la chaîne de traduction. Donc, il accepte des paramètres de deux manières : soit comme une liste de
paramètres, soit comme un tableau de paramètres. Par exemple :Paramètres uniquePour utiliser un paramètre unique, ajoutez le en fin de méthode :translate("Today is %1\$s", $date);
// ceci retourne 'Heute ist Monday'
]]>Gardez à l'esprit que si vous utilisez des paramètres qui sont aussi des textes, vous pouvez aussi avoir à
traduire ces paramètres.Liste de paramètresOu utiliser une liste de paramètres et ajoutez les en fin de méthode :translate("Today is %1\$s in %2\$s. Actual time: %3\$s",
$date,
$month,
$time);
// ceci retourne 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55'
]]>Tableau de paramètresOu utiliser un tableau de paramètres et ajoutez le en fin de méthode :translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
// Could return 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55'
]]>Parfois il est nécessaire de changer la locale pour une traduction. Ceci peut être fait soit dynamiquement par
traduction ou statiquement pour toutes les traductions suivantes. Et vous pouvez utiliser ceci avec une liste de
paramètres ou un tableau de paramètres. Dans les deux cas la locale doit être fournie comme un paramètre unique
final.Changement dynamique de la localetranslate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date, 'it');
]]>Cet exemple retourne la traduction italienne pour l'identifiant de message. Mais la locale ne sera utilisée
qu'une seule fois. La traduction suivante utilisera la locale de l'adaptateur. Normalement vous réglerez la locale
au niveau de votre adaptateur avant de le mettre dans le registre. Mais vous pouvez aussi paramétrer la locale avec
l'aide de vue :Changement statique de la localetranslate()->setLocale('it');
$this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
]]>L'exemple ci-dessus paramètre 'it' comme nouvelle locale par défaut, elle sera utilisée pour
toutes les traductions ultérieures.Bien sûr il existe aussi la méthode getLocale() pour récupérer le réglage courant de la
locale.Récupération de la locale courantetranslate()->getLocale();
$this->translate()->setLocale('it');
$this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date);
// retourne 'it' comme nouvelle locale par défaut
$this->translate()->getLocale();
]]>