2
0

Zend_Validate-InArray.xml 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17894 -->
  3. <!-- Reviewed: no -->
  4. <sect2 id="zend.validate.set.in_array">
  5. <title>InArray</title>
  6. <para>
  7. <classname>Zend_Validate_InArray</classname> erlaubt es zu prüfen ob ein gegebener Wert
  8. in einem Array enthalten ist. Er ist auch in der Lage mehrdimensionale Arrays zu prüfen.
  9. </para>
  10. <sect3 id="zend.validate.set.in_array.basic">
  11. <title>Einfache Array Prüfung</title>
  12. <para>
  13. Der einfachste Weg ist es, das Array welches durchsucht werden soll, bei der
  14. Initiierung anzugeben:
  15. </para>
  16. <programlisting language="php"><![CDATA[
  17. $validator = new Zend_Validate_InArray(array('key' => 'value',
  18. 'otherkey' => 'othervalue'));
  19. if ($validator->isValid('value')) {
  20. // Wert gefunden
  21. } else {
  22. // Wert nicht gefunden
  23. }
  24. ]]></programlisting>
  25. <para>
  26. Das verhält sich genauso wie <acronym>PHP</acronym>'s
  27. <methodname>in_array()</methodname> Methode.
  28. </para>
  29. <note>
  30. <para>
  31. Standardmäßig ist diese Prüfung nicht strikt noch kann Sie mehrdimensionale Arrays
  32. prüfen.
  33. </para>
  34. </note>
  35. <para>
  36. Natürlich kann man das Array gegen das geprüft werden soll auch im Nachhinein durch
  37. Verwendung der <methodname>setHaystack()</methodname> Methode angegeben werden.
  38. </para>
  39. <programlisting language="php"><![CDATA[
  40. $validator = new Zend_Validate_InArray();
  41. $validator->setHaystack(array('key' => 'value', 'otherkey' => 'othervalue'));
  42. if ($validator->isValid('value')) {
  43. // Wert gefunden
  44. } else {
  45. // Wert nicht gefunden
  46. }
  47. ]]></programlisting>
  48. </sect3>
  49. <sect3 id="zend.validate.set.in_array.strict">
  50. <title>Strikte Array Prüfung</title>
  51. <para>
  52. Wie vorher erwähnt kann man auch eine Strikte Prüfung im Array durchführen.
  53. Standardmäßig würde kein Unterschied zwischen dem Integerwert <emphasis>0</emphasis>
  54. und dem String <emphasis>"0"</emphasis> sein. Wenn eine strikte Prüfung durchgeführt
  55. wird dann wird dieser Unterschied auch geprüft und nur gleiche Typen werden akzeptiert.
  56. </para>
  57. <para>
  58. Eine strikte Prüfung kann auch auf zwei verschiedenen Wegen durchgeführt werden. Bei
  59. der Initiierung und durch Verwendung einer Methode. Bei der Initiierung muß hierfür ein
  60. Array mit der folgenden Struktur angegeben werden:
  61. </para>
  62. <programlisting language="php"><![CDATA[
  63. $validator = new Zend_Validate_InArray(
  64. array(
  65. 'haystack' => array('key' => 'value', 'otherkey' => 'othervalue'),
  66. 'strict' => true
  67. )
  68. );
  69. if ($validator->isValid('value')) {
  70. // Wert gefunden
  71. } else {
  72. // Wert nicht gefunden
  73. }
  74. ]]></programlisting>
  75. <para>
  76. Der <emphasis>haystack</emphasis> Schlüssel enthält das eigene Array das für die
  77. Prüfung verwendet wird. Durch das Setzen des <emphasis>script</emphasis> Schlüssels
  78. auf <constant>TRUE</constant> wird die Prüfung so durchgeführt, das der Typ strikt
  79. geprüft wird.
  80. </para>
  81. <para>
  82. Natürlich kann man auch die <methodname>setStrict()</methodname> Methode verwenden
  83. um diese Einstellung im Nachhinein zu ändern.
  84. </para>
  85. <note>
  86. <para>
  87. Es ist zu beachten das die <emphasis>strict</emphasis> Einstellung standardmäßig
  88. <constant>FALSE</constant> ist.
  89. </para>
  90. </note>
  91. </sect3>
  92. <sect3 id="zend.validate.set.in_array.recursive">
  93. <title>Rekursive Array Prüfung</title>
  94. <para>
  95. Zusätzlich zu <acronym>PHP</acronym>'s <methodname>in_array()</methodname> Methode kann
  96. diese Prüfung auch verwendet werden um Mehrdimensionale Arrays zu prüfen.
  97. </para>
  98. <para>
  99. Um mehrdimensionale Array zu prüfen muß die <emphasis>recursive</emphasis> Option
  100. gesetzt werden.
  101. </para>
  102. <programlisting language="php"><![CDATA[
  103. $validator = new Zend_Validate_InArray(
  104. array(
  105. 'haystack' => array(
  106. 'firstDimension' => array('key' => 'value',
  107. 'otherkey' => 'othervalue'),
  108. 'secondDimension' => array('some' => 'real',
  109. 'different' => 'key')),
  110. 'recursive' => true
  111. )
  112. );
  113. if ($validator->isValid('value')) {
  114. // Wert gefunden
  115. } else {
  116. // Wert nicht gefunden
  117. }
  118. ]]></programlisting>
  119. <para>
  120. Das eigene Array wird das rekursiv geprüft um zu sehen ob der angegebene Wert enthalten
  121. ist.
  122. </para>
  123. <note>
  124. <para>
  125. Es ist zu beachten das die rekursive Prüfung standardmäßig ausgeschaltet ist.
  126. </para>
  127. </note>
  128. </sect3>
  129. </sect2>
  130. <!--
  131. vim:se ts=4 sw=4 et:
  132. -->