Zend_Validate-Messages.xml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21661 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.validate.messages">
  5. <title>Prüfungsmeldungen</title>
  6. <para>
  7. Jede Prüfung die auf <classname>Zend_Validate</classname> basiert, bietet im Fall einer
  8. fehlgeschlagen Prüfung eine oder mehrere Meldungen an. Diese Information kann verwendet
  9. werden um eigene Meldungen zu setzen, oder bestehende Meldungen welche eine Prüfung
  10. zurückgeben könnte, auf etwas anderes zu übersetzen.
  11. </para>
  12. <para>
  13. Diese Prüfmeldungen sind Konstanten welche am Beginn jeder Prüfklasse gefunden werden
  14. können. Sehen wir uns für ein beschreibendes Beispiel
  15. <classname>Zend_Validate_GreaterThan</classname> an:
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. protected $_messageTemplates = array(
  19. self::NOT_GREATER => "'%value%' is not greater than '%min%'",
  20. );
  21. ]]></programlisting>
  22. <para>
  23. Wie man siehr referenziert die Konstante <constant>self::NOT_GREATER</constant> auf den
  24. Fehler und wird als Schlüssel verwendet. Und die Nachricht selbst ist der Wert des
  25. Nachrichtenarrays.
  26. </para>
  27. <para>
  28. Man kann alle Nachrichten Templates einer Prüfung erhalten indem man die Methode
  29. <methodname>getMessageTemplates()</methodname> verwendet. Diese gibt das oben stehende array
  30. zurück, welches alle Nachrichten enthält die eine Prüfung im Falle einer fehlgeschlagenen
  31. Prüfung zurückgeben kann.
  32. </para>
  33. <programlisting language="php"><![CDATA[
  34. $validator = new Zend_Validate_GreaterThan();
  35. $messages = $validator->getMessageTemplates();
  36. ]]></programlisting>
  37. <para>
  38. Indem die Methode <methodname>setMessage()</methodname> verwendet wird kann man eine andere
  39. Meldung definieren die im Fall des spezifizierten Fehlers zurückgegeben werden.
  40. </para>
  41. <programlisting language="php"><![CDATA[
  42. $validator = new Zend_Validate_GreaterThan();
  43. $validator->setMessage('Bitte einen kleineren Wert angeben', Zend_Validate_GreaterThan::NOT_GREATER);
  44. ]]></programlisting>
  45. <para>
  46. Der zweite Parameter definiert den Fehler der überschrieben wird. Wenn man diesen Parameter
  47. nicht angibt, wird die angegebene Meldung für alle möglichen Fehler dieser Prüfung gesetzt.
  48. </para>
  49. <sect2 id="zend.validate.messages.pretranslated">
  50. <title>Verwendung vor-übersetzter Prüfungsmeldungen</title>
  51. <para>
  52. Zend Framework wird mit mehr als 45 unterschiedlichen Prüfern und mehr als 200
  53. Fehlermeldungen ausgeliefert. Es kann eine zeitraubende Aufgabe sein alle diese
  54. Meldungen zu übersetzen. Aber der Bequemlichkeit halber kommt Zend Framework mit
  55. bereits vor-übersetzten Prüfmeldungen. Diese können im Pfad
  56. <filename>/resources/languages</filename> der eigenen Zend Framework Installation
  57. gefunden werden.
  58. </para>
  59. <note>
  60. <title>Verwendeter Pfad</title>
  61. <para>
  62. Die Ressource Dateien liegen ausserhalb des Bibliothekspfads weil alle Übersetzungen
  63. ausserhalb dieses Pfades liegen sollten.
  64. </para>
  65. </note>
  66. <para>
  67. Um also alle Prüfmeldungen zum Beispiel auf Deutsch zu übersetzen muss man nur einen
  68. Übersetzer an <classname>Zend_Validate</classname> anhängen der diese Ressourcedateien
  69. verwendet.
  70. </para>
  71. <programlisting language="php"><![CDATA[
  72. $translator = new Zend_Translate(
  73. array(
  74. 'adapter' => 'array',
  75. 'content' => '/resources/languages',
  76. 'locale' => $language,
  77. 'scan' => Zend_Translate::LOCALE_DIRECTORY
  78. )
  79. );
  80. Zend_Validate_Abstract::setDefaultTranslator($translator);
  81. ]]></programlisting>
  82. <note>
  83. <title>Verwendeter Übersetzungsadapter</title>
  84. <para>
  85. Als Übersetzungsadapter hat Zend Framework den Array Adapter ausgewählt. Er ist
  86. einfach zu bearbeiten und sehr schnell erstellt.
  87. </para>
  88. </note>
  89. <note>
  90. <title>Unterstützte Sprachen</title>
  91. <para>
  92. Dieses Feature ist sehr jung, und deshalb ist die Anzahl der unterstützten Sprachen
  93. nicht sehr komplett. Neue Sprachen werden mit jedem Release hinzugefügt. Zusätzlich
  94. können die existierenden Ressourcedateien verwendet werden um eigene Übersetzungen
  95. durchzuführen.
  96. </para>
  97. <para>
  98. Man kann diese Ressource Dateien auch verwenden um existierende Übersetzungen
  99. umzuschreiben. Man muss diese Dateien also nicht selbst per Hand erstellen.
  100. </para>
  101. </note>
  102. </sect2>
  103. <sect2 id="zend.validate.messages.limitation">
  104. <title>Begrenzen der Größe einer Prüfungsmeldung</title>
  105. <para>
  106. Manchmal ist es notwendig die maximale Größe die eine Prüfungsmeldung haben kann zu
  107. begrenzen. Zum Beispiel wenn die View nur eine maximale Größe von 100 Zeichen für die
  108. Darstellung auf einer Zeile erlaubt. Um die Verwendung zu vereinfachen, ist
  109. <classname>Zend_Validate</classname> dazu in der Lage die maximal zurückgegebene
  110. Größe einer Prüfnachricht zu begrenzen.
  111. </para>
  112. <para>
  113. Um die aktuell gesetzte Größe zu erhalten ist
  114. <methodname>Zend_Validate::getMessageLength()</methodname> zu verwenden. Wenn diese
  115. -1 ist, dann wird die zurückgegebene Nachricht nicht begrenzt. Das ist das
  116. Standardverhalten.
  117. </para>
  118. <para>
  119. Um die Größe der zurückgegebenen Nachrichten zu begrenzen ist
  120. <methodname>Zend_Validate::setMessageLength()</methodname> zu verwenden. Man kann diese
  121. auf jede benötigte Integer Größe setzen. Wenn die zurückzugebende Nachricht die
  122. gesetzte Größe überschreitet, dann wird die Nachricht abgeschnitten und der String
  123. '<emphasis>...</emphasis>' wird statt dem Rest der Nachricht hinzugefügt.
  124. </para>
  125. <programlisting language="php"><![CDATA[
  126. Zend_Validate::setMessageLength(100);
  127. ]]></programlisting>
  128. <note>
  129. <title>Wo wird dieser Parameter verwendet?</title>
  130. <para>
  131. Die gesetzte Länge der Nachrichten wird für alle Prüfungen verwendet, sogar für
  132. selbstdefinierte, solange Sie <classname>Zend_Validate_Abstract</classname>
  133. erweitern.
  134. </para>
  135. </note>
  136. </sect2>
  137. </sect1>