Zend_Validate-Messages.xml 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 21213 -->
  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. '/resources/languages',
  75. $language,
  76. array('scan' => Zend_Translate::LOCALE_DIRECTORY)
  77. );
  78. Zend_Validate_Abstract::setDefaultTranslator($translator);
  79. ]]></programlisting>
  80. <note>
  81. <title>Verwendeter Übersetzungsadapter</title>
  82. <para>
  83. Als Übersetzungsadapter hat Zend Framework den Array Adapter ausgewählt. Er ist
  84. einfach zu bearbeiten und sehr schnell erstellt.
  85. </para>
  86. </note>
  87. <note>
  88. <title>Unterstützte Sprachen</title>
  89. <para>
  90. Dieses Feature ist sehr jung, und deshalb ist die Anzahl der unterstützten Sprachen
  91. nicht sehr komplett. Neue Sprachen werden mit jedem Release hinzugefügt. Zusätzlich
  92. können die existierenden Ressourcedateien verwendet werden um eigene Übersetzungen
  93. durchzuführen.
  94. </para>
  95. <para>
  96. Man kann diese Ressource Dateien auch verwenden um existierende Übersetzungen
  97. umzuschreiben. Man muss diese Dateien also nicht selbst per Hand erstellen.
  98. </para>
  99. </note>
  100. </sect2>
  101. <sect2 id="zend.validate.messages.limitation">
  102. <title>Begrenzen der Größe einer Prüfungsmeldung</title>
  103. <para>
  104. Manchmal ist es notwendig die maximale Größe die eine Prüfungsmeldung haben kann zu
  105. begrenzen. Zum Beispiel wenn die View nur eine maximale Größe von 100 Zeichen für die
  106. Darstellung auf einer Zeile erlaubt. Um die Verwendung zu vereinfachen, ist
  107. <classname>Zend_Validate</classname> dazu in der Lage die maximal zurückgegebene
  108. Größe einer Prüfnachricht zu begrenzen.
  109. </para>
  110. <para>
  111. Um die aktuell gesetzte Größe zu erhalten ist
  112. <methodname>Zend_Validate::getMessageLength()</methodname> zu verwenden. Wenn diese
  113. -1 ist, dann wird die zurückgegebene Nachricht nicht begrenzt. Das ist das
  114. Standardverhalten.
  115. </para>
  116. <para>
  117. Um die Größe der zurückgegebenen Nachrichten zu begrenzen ist
  118. <methodname>Zend_Validate::setMessageLength()</methodname> zu verwenden. Man kann diese
  119. auf jede benötigte Integer Größe setzen. Wenn die zurückzugebende Nachricht die
  120. gesetzte Größe überschreitet, dann wird die Nachricht abgeschnitten und der String
  121. '<emphasis>...</emphasis>' wird statt dem Rest der Nachricht hinzugefügt.
  122. </para>
  123. <programlisting language="php"><![CDATA[
  124. Zend_Validate::setMessageLength(100);
  125. ]]></programlisting>
  126. <note>
  127. <title>Wo wird dieser Parameter verwendet?</title>
  128. <para>
  129. Die gesetzte Länge der Nachrichten wird für alle Prüfungen verwendet, sogar für
  130. selbstdefinierte, solange Sie <classname>Zend_Validate_Abstract</classname>
  131. erweitern.
  132. </para>
  133. </note>
  134. </sect2>
  135. </sect1>