Zend_Validate-NotEmpty.xml 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <sect2 id="zend.validate.set.notempty">
  4. <title>NotEmpty</title>
  5. <para>
  6. Ce validateur permet de déterminer si une valeur est non vide. C'est utile lorsque vous travaillez
  7. avec des formulaires ou des entrées utilisateur, là où vous pouvez l'utiliser pour savoir si des
  8. éléments requis ont été saisis.
  9. </para>
  10. <sect3 id="zend.validate.set.notempty.default">
  11. <title>Comportement par défaut de Zend_Validate_NotEmpty</title>
  12. <para>
  13. Par défaut, ce validateur fonctionne différement de la fonction
  14. <acronym>PHP</acronym> <methodname>empty()</methodname>. En particulier, ce validateur va
  15. évaluer l'entier <emphasis>0</emphasis> et la chaine '<emphasis>0</emphasis>' comme vides.
  16. </para>
  17. <programlisting language="php"><![CDATA[
  18. $valid = new Zend_Validate_NotEmpty();
  19. $value = '';
  20. $result = $valid->isValid($value);
  21. // retourne false
  22. ]]></programlisting>
  23. <note>
  24. <title>Le comportement par défaut diffère de PHP</title>
  25. <para>
  26. Sans configuration ajoutée, <classname>Zend_Validate_NotEmpty</classname> diffère
  27. de <acronym>PHP</acronym>.
  28. </para>
  29. </note>
  30. </sect3>
  31. <sect3 id="zend.validate.set.notempty.types">
  32. <title>Changer le comportement de Zend_Validate_NotEmpty</title>
  33. <para>
  34. Certains projets ont des opinions différentes sur ce qui peut être considéré comme 'vide'.
  35. Une chaine seulement composée d'espaces blancs pourrait être considérée comme vide, ou
  36. <emphasis>0</emphasis> pourrait être considéré comme non-vide (surtout dans les séquences
  37. logiques booléennes). Pour correspondre aux différents besoins,
  38. <classname>Zend_Validate_NotEmpty</classname> vous permet de configurer les types que vous
  39. considérez comme vides.
  40. </para>
  41. <para>
  42. Les types suivants sont gérés:
  43. </para>
  44. <itemizedlist>
  45. <listitem>
  46. <para>
  47. <emphasis>booléen</emphasis>: Retourne <constant>FALSE</constant> lorsque
  48. la valeur booléenne est <constant>FALSE</constant>.
  49. </para>
  50. </listitem>
  51. <listitem>
  52. <para>
  53. <emphasis>entier</emphasis>: Retourne <constant>FALSE</constant> lorsque l'entier
  54. <emphasis>0</emphasis> est passé. Par défaut cette validation n'est pas activée et
  55. retourne <constant>TRUE</constant> pour toute valeur d'entier.
  56. </para>
  57. </listitem>
  58. <listitem>
  59. <para>
  60. <emphasis>flottant</emphasis>: Retourne <constant>FALSE</constant> lorsque le flottant
  61. <emphasis>0.0</emphasis> est passé. Par défaut cette validation n'est pas activée et
  62. retourne <constant>TRUE</constant> pour toute valeur de flottant.
  63. </para>
  64. </listitem>
  65. <listitem>
  66. <para>
  67. <emphasis>chaine</emphasis>: Retourne <constant>FALSE</constant> lorsque la chaine vide
  68. <emphasis>''</emphasis> est passée.
  69. </para>
  70. </listitem>
  71. <listitem>
  72. <para>
  73. <emphasis>zero</emphasis>: Retourne <constant>FALSE</constant> lorsque le seul caractère
  74. zéro (<emphasis>'0'</emphasis>) est passé.
  75. </para>
  76. </listitem>
  77. <listitem>
  78. <para>
  79. <emphasis>tableau_vide</emphasis>: Retourne <constant>FALSE</constant> lorsqu'un tableau vide
  80. <emphasis>array()</emphasis> est passé.
  81. </para>
  82. </listitem>
  83. <listitem>
  84. <para>
  85. <emphasis>null</emphasis>: Retourne <constant>FALSE</constant> lorsqu'une valeur
  86. <constant>NULL</constant> est passée.
  87. </para>
  88. </listitem>
  89. <listitem>
  90. <para>
  91. <emphasis>php</emphasis>: Retourne <constant>FALSE</constant> lorsque la fonction
  92. <acronym>PHP</acronym> <methodname>empty()</methodname> retournerait
  93. <constant>TRUE</constant>.
  94. </para>
  95. </listitem>
  96. <listitem>
  97. <para>
  98. <emphasis>espace</emphasis>: Retourne <constant>FALSE</constant> lorsqu'une chaine
  99. ne contenant que des caractères espace est passée.
  100. </para>
  101. </listitem>
  102. <listitem>
  103. <para>
  104. <emphasis>tout</emphasis>: Retourne <constant>FALSE</constant> pour tous les
  105. types gérés cités ci-dessus.
  106. </para>
  107. </listitem>
  108. </itemizedlist>
  109. <para>
  110. Toute autre valeur passée retourne <constant>TRUE</constant> par défaut.
  111. </para>
  112. <para>
  113. Il existe différentes manières de selectionner les types ci-dessus. Vous pouvez en spécifier
  114. un ou plusieurs, sous forme de tableau ou de constantes ou encore de chaines.
  115. Voyez les exemples ci-après:
  116. </para>
  117. <programlisting language="php"><![CDATA[
  118. // Retourne false pour 0
  119. $validator = new Zend_Validate_NotEmpty(Zend_Validate_NotEmpty::INTEGER);
  120. // Retourne false pour 0 ou '0'
  121. $validator = new Zend_Validate_NotEmpty(
  122. Zend_Validate_NotEmpty::INTEGER + Zend_NotEmpty::ZERO
  123. );
  124. // Retourne false pour 0 ou '0'
  125. $validator = new Zend_Validate_NotEmpty(array(
  126. Zend_Validate_NotEmpty::INTEGER,
  127. Zend_Validate_NotEmpty::ZERO
  128. ));
  129. // Retourne false pour 0 ou '0'
  130. $validator = new Zend_Validate_NotEmpty(array(
  131. 'integer',
  132. 'zero',
  133. ));
  134. ]]></programlisting>
  135. <para>
  136. Il est aussi possible de passer un objet <classname>Zend_Config</classname> afin de
  137. préciser les types à utiliser. Après instantiation, <methodname>setType()</methodname>
  138. peut être utilisée.
  139. </para>
  140. </sect3>
  141. </sect2>
  142. <!--
  143. vim:se ts=4 sw=4 et:
  144. -->