Übersetzungs Helfer Oft sind Webseiten in verschiedenen Sprachen vorhanden. Um den Inhalt einer Site zu übersetzen sollte ganz einfach Zend_Translate verwendet werden, und um Zend_Translate in der eigenen View zu integrieren sollte der Translate View Helfer verwendet werden. In allen folgenden Beispielen verwenden wir den einfachen Array Übersetzungs Adapter. Natürlich kann jede Instanz von Zend_Translate und genauso jede Subklasse von Zend_Translate_Adapter verwendet werden. Es gibt verschiedene Wege den Translate View Helfer zu initiieren: Registriert, durch eine vorher in Zend_Registry registrierte Instanz Danach, durch das Fluent Interface Direkt, durch Instanzierung der Klasse Eine registrierte Instanz von Zend_Translate ist die bevorzugte Verwendung für diesen Helfer. Bevor der Adapter der Registry hinzugefügt wird, kann das zu verwendende Gebietsschema einfach ausgewählt werden. Wir sprechen hier von Gebietsschemata (Locale) statt von Sprachen weil eine Sprache auch in verschiedenen Regionen vorhanden sein kann. Zum Beispiel wird Englisch in verschiedenen Dialekten gesprochen. Es könnte eine Übersetzung für Britisch und eine für Amerikanisches Englisch geben. Deswegen sagen wir Gebietsschema "locale" statt Sprache. Registrierte Instanz Um eine registrierte Instanz zu verwenden muß einfach eine Instanz von Zend_Translate oder Zend_Translate_Adapter erstellt werden und in Zend_Registry durch Verwendung des Schlüssels Zend_Translate registriert werden. 'array', 'content' => array('simple' => 'einfach'), 'locale' => 'de' ) ); Zend_Registry::set('Zend_Translate', $adapter); // In der View echo $this->translate('simple'); // gibt 'einfach' zurück ]]> Wenn man mit dem Fluent Interface besser zurecht kommt, kann eine Instanz auch in der View erstellt werden und der Helfer im Nachhinein initiiert werden. In der View Um das Fluid Interface zu verwenden muß eine Instanz von Zend_Translate oder Zend_Translate_Adapter erstellt werden, der Helfer ohne Parameter und anschließend die setTranslator() Methode aufgerufen werden. 'array', 'content' => array('simple' => 'einfach'), 'locale' => 'de' ) ); $this->translate()->setTranslator($adapter)->translate('simple'); // das gibt 'einfach' zurück ]]> Wenn der Helfer ohne Zend_View verwendet werden soll kann er auch direkt angesprochen werden. Direkte Verwendung 'array', 'content' => array('simple' => 'einfach'), 'locale' => 'de' ) ); // den Helfer initiieren $translate = new Zend_View_Helper_Translate($adapter); print $translate->translate('simple'); // das gibt 'einfach' zurück ]]> Dieser Weg kann verwendet werden wenn man nicht mit Zend_View arbeitet und übersetzte Ausgaben erzeugen muß. Wie man bereits sehen konnte, wird die translate() Methode verwendet um die Übersetzung zurückzugeben. Sie muss nur mit der benötigten messageid des Übersetzungsadapters aufgerufen werden. Aber sie kann auch Parameter im Übersetzungsstring ersetzen. Deswegen akzeptiert Sie variable Parameter in zwei Wegen: entweder als Liste von Parametern, oder als Array von Parametern. Als Beispiel: Einzelne Parameter Um einen einzelnen Parameter zu verwenden muss dieser einfach der Methode angefügt werden. translate("Today is %1\$s", $date); // könnte 'Heute ist Montag' zurückgeben ]]> Wenn man Parameter verwendet die auch Text sind ist zu beachten das es auch nötig sein kann diese Parameter zu übersetzen. Liste von Parametern Oder eine Liste von Parametern verwenden und diese der Methode hinzufügen. translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date, $month, $time); // könnte 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55' zurückgeben ]]> Array von Parametern Oder ein Array von Parametern verwenden und dieses der Methode hinzufügen. translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date); // könnte 'Heute ist Monday in April. Aktuelle Zeit: 11:20:55' zurückgeben ]]> Manchmal ist es notwendig das Gebietsschema der Übersetzung zu Ändern. Das kann entweder dynamisch pro Übersetzung oder statisch für alle folgenden Übersetzungen durchgeführt werden. Dies kann mit beidem, einer Liste von Paramtern oder einem Array von Parametern, verwendet werden. In beiden Fällen muss das als letzter einzelner Parameter angegeben werden. Das Gebietsschema dynamisch wechseln translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date, 'it'); ]]> Dieses Beispiel gibt die italienische Übersetzung für die messageid zurück. Aber Sie wird nur einmal verwendet. Die nächste Übersetzung verwendet wieder das Gebietsschema des Adapters. Normalerweise wird das gewünschte Gebietsschema im Übersetzungsadapter gesetzt bevor dieser der Registry hinzugefügt wird. Das Gebietsschema kann aber auch im Helfer gesetzt werden: Das Gebietsschema statisch wechseln translate()->setLocale('it'); $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date); ]]> Das obige Beispiel setzt 'it' als neues standardmäßiges Gebietsschema welches für alle weiteren Übersetzungen verwendet wird. Natürlich gibt es auch eine getLocale() Methode um das aktuell gesetzte Gebietsschema zu erhalten. Das aktuell gesetzte Gebietsschema erhalten translate()->getLocale(); $this->translate()->setLocale('it'); $this->translate("Today is %1\$s in %2\$s. Actual time: %3\$s", $date); // gibt 'it' als neues standardmäßig gesetztes Gebietsschema zurück $this->translate()->getLocale(); ]]>