Zend Framework est fournis avec des classes d'éléments couvrant la plupart des éléments de formulaire HTML. La plupart spécifie un helper de vue en particulier à utiliser pour décorer un élément, mais plusieurs d'entre elles offrent des fonctionnalités supplémentaires. Ce qui suit est une liste de toutes ces classes, ainsi que des descriptions des fonctionnalités offertes.
Utilisé pour créer des éléments boutons,
Zend_Form_Element_Button
étend Zend_Form_Element_Submit,
spécifie quelques fonctionnalités personnalisées. Il spécifie le
helper de vue 'formButton' pour la décoration.
Comme l'élément submit, il utilise le label de l'élément en tant que valeur de l'élément lors de l'affichage ; autrement dit, pour définir le text du bouton, définissez la valeur de l'élément. Le label sera traduit si l'adapteur de traduction est présent.
Comme le label est utilisé comme faisant partie de l'élément, l'élément bouton utilise seulement ViewHelper et les décorateurs DtDdWrapper.
Les CAPTCHAs sont utilisé pour empêcher la soumission automatique des formulaires par des bots et autre processus automatisés.
L'élément de formulaire Captcha permet de spécifier quel Adapteur Zend_Captcha vous désirez utiliser. Il définit ensuite cet adapteur comme validateur à l'objet, et utilise le décorateur du Captcha pour l'affichage (ce qui fait office de proxy vers l'adapteur CAPTCHA).
Les adapteurs peuvent être n'importe quel adapteur de
Zend_Captcha
, ou n'importe quel adapteur que
vous avez défini par ailleurs. Pour permettre ceci, vous devrez passer
une clé supplémentaire de plugin loader, 'CAPTCHA'
ou 'captcha', lorsque vous spécifiez un prefixe de chemin de plugin loader :
$element->addPrefixPath('My_Captcha', 'My/Captcha/', 'captcha');
Le Captcha peut ensuite être enregistré en utilisant la méthode
setCaptcha()
, qui prend en paramètre soit
une instance concrête de CAPTCHA soit le nom court d'un adapteur CAPTCHA :
// Instance concrête: $element->setCaptcha(new Zend_Captcha_Figlet()); // Utilisation d'un nom court : $element->setCaptcha('Dumb');
Si vous souhaitez charger votre élément via la configuration, spécifiez soit la clé 'captcha' avec un tableau contenant la clé 'captcha', soit les clés 'captcha' et 'captchaOptions' :
// Utilisation d'une clé captcha : $element = new Zend_Form_Element_Captcha('foo', array( 'label' => "Merci de confirmer que vous êtes humain", 'captcha' => array( 'captcha' => 'Figlet', 'wordLen' => 6, 'timeout' => 300, ), )); // Utilisation simultanée des clés captcha et captchaOption : $element = new Zend_Form_Element_Captcha('foo', array( 'label' => "Merci de confirmer que vous êtes humain", 'captcha' => 'Figlet', 'captchaOptions' => array( 'captcha' => 'Figlet', 'wordLen' => 6, 'timeout' => 300, ), ));
Le décorateur utilisé est déterminé lors de la récupération de l'adapteur
du captcha. Par défaut, le décorateur
du captcha est utilisé, mais un adapteur peut spécifier un décorateur
différent via sa méthode getDecorator()
.
Comme noté, l'adapteur de captcha lui même agit comme un validateur pour l'élément. De plus, le validateur NotEmpty n'est pas utilisé, et l'élément est marqué comme requis. Dans la plupart des cas, vous n'aurez besoin de rien d'autre pour que le captcha soit présent dans votre formulaire.
Les cases à cocher HTML vous permettent de retourner une valeur spécifique,
mais elles fonctionnent essentiellement comme des booléens. Lorsque elle
est cochée, la valeur de la case à cocher est soumise. Lorsque la case à
cocher n'est pas cochée, rien n'est soumis. En interne,
Zend_Form_Element_Checkbox
applique cet état.
Par défaut, la valeur cochée est '1', et la valeur non cochée est '0'.
Vous pouvez spécifier les valeurs en utilisant respectivement les accesseurs
setCheckedValue()
et setUncheckedValue()
. En interne, à chaque fois que
vous définissez une valeur, si la valeur fournie correspond à la valeur cochée,
alors elle sera définie, mais toutes autres valeurs aura pour effet que la valeur
non cochée sera sélectionnée.
En sus, définir la valeur définit la propriété checked
de la case à cocher. Vous pouvez la récupérer en utilisant
isChecked()
ou simplement en accédant à la propriété.
Utiliser la méthode setChecked($flag)
l'état du flag
ainsi que la valeur cochée ou non cochée de l'élément.
Veillez à utiliser cette méthode lorsque vous définissez l'état coché d'un élément
case à cocher afin d'être sûr que la valeur est correctement définie.
Zend_Form_Element_Checkbox
utilise le helper de vue
'formCheckbox'. La valeur cochée est toujours utilisé pour le remplir.
L'élément de formulaire File fournit un mécanisme pour fournir des champs
d'upload de fichier à votre formulaire. Il utilise Zend_File_Transfer
en interne pour fournir cette fonctionnalité et le helper de vue
FormFile
ainsi que le décorateur File
pour afficher l'élément de formulaire.
Par défaut, il utilise l'adapteur de transfertHttp
qui
inspecte le tableau $_FILES
et vous permet d'attacher
des validateurs et des filtres. Les validateurs et les filtres attachés
au formulaire sont à leur tour attachés à l'adapteur de transfert.
Exemple 445. Utilisation de l'élément de formulaire File
L'explication d'utilisation de l'élément de formulaire File ci-dessous peut sembler ésotérique, mais l'usage est en fait relativement trivial :
$element = new Zend_Form_Element_File('foo'); $element->setLabel('Upload une image:') ->setDestination('/var/www/upload'); // Fait en sorte qu'il y ait un seul fichier $element->addValidator('Count', false, 1); // limite à 100K $element->addValidator('Size', false, 102400); // seulement des JPEG, PNG, et GIFs $element->addValidator('Extension', false, 'jpg,png,gif'); $form->addElement($element, 'foo');
Vous devez aussi vous assurer que le type d'encodage correct est fourni au formulaire ; vous devez utiliser 'multipart/form-data'. Vous pouvez faire cela en définissant l'attribut 'enctype' du formulaire:
$form->setAttrib('enctype', 'multipart/form-data');
Après que le formulaire soit validé avec succès, vous devriez recevoir
le fichier afin de le stocker dans sa destination finale en utilisant
receive()
.
De plus, vous pouvez déterminer son emplacement finale en utilisant
getFileName()
:
if (!$form->isValid()) { print "Uh oh... erreur de validation"; } if (!$form->foo->receive()) { print "Erreur de réception de fichier"; } $location = $form->foo->getFileName();
Emplacement d'upload par défaut
Par défaut, les fichiers sont uploadés dans le répertoire temp du système.
Valeur de fichier
Au sein du HTTP un élément fichier n'a aucune valeur.
Pour cette raison et pour des raisons de sécurité
getValue()
retourne seulement le nom du fichier
uploadé et non le chemin complet. Si vous avez besoin du chemin du fichier,
appellez getFileName()
, qui retourne à la fois le
chemin et le nom du fichier.
Par défaut, le fichier sera automatiquement reçu quand vous appellerez
getValues()
sur le formulaire. La raison derrière
ce comportement est que le fichier lui même est la valeur de l'élément fichier.
$form->getValues();
Note
Ainsi, un appel supplémentaire de receive()
après avoir
appellé getValues()
n'aura aucun effet. De même, créer
une instance de Zend_File_Transfer
n'aura aucun effet non
plus puisqu'il n'y aura plus de fichier à recevoir.
Cela dit, parfois vous aurez besoin d'appeller getValues()
sans
recevoir le fichier. Vous pouvez l'archiver en appellant
setValueDisabled(true)
. Afin de recevoir la véritable valeur de
ce flag vous pouvez appeller isValueDisabled()
.
Exemple 446. Récupération explicite de fichier
Tout d'abord appellezsetValueDisabled(true)
.
$element = new Zend_Form_Element_File('foo'); $element->setLabel('Uploadez une image:') ->setDestination('/var/www/upload') ->setValueDisabled(true);
Désormais le fichier sera reçu lorsque vous appellerez
getValues()
. Donc vous devez appeller vous même
receive()
sur l'élément fichier, ou une instance de
Zend_File_Transfer
.
$values = $form->getValues(); if ($form->isValid($form->getPost())) { if (!$form->foo->receive()) { print "Erreur d'upload"; } }
Il ya plusieurs étapes du fichier uploadés qui peuvent être vérifiées avec les méthodes suivantes :
-
isUploaded()
: Vérifie si l'élément fichier a été uploadé ou non. -
isReceived()
: Vérifie si l'élément fichier a déjà été reçu. -
isFiltered()
: Vérifie si les filtres ont déjà été appliqué ou non sur l'élément fichier.
Exemple 447. Vérifier si un fichier optionnel a été uploadé
$element = new Zend_Form_Element_File('foo'); $element->setLabel('Uploader une image:') ->setDestination('/var/www/upload') ->setRequired(false); $element->addValidator('Size', false, 102400); $form->addElement($element, 'foo'); // L'élément fichier foo est optionnel mais quand il est renseigné va là if ($form->foo->isUploaded()) { // fichier foo donné, faire quelque chose }
Zend_Form_Element_File
supporte aussi les fichiers multiples.
En appellant la méthode setMultiFile($count)
vous pouvez définir,
le nombre d'éléments fichier à créer. Ceci vous évite de définir les mêmes
réglages plusieurs fois.
Exemple 448. Définir plusieurs fichiers
Créer un élément multifichier est identique à la création d'un élément unique.
Appellez simplement setMultiFile()
après que l'élément soit créé:
$element = new Zend_Form_Element_File('foo'); $element->setLabel('Uploadez une image:') ->setDestination('/var/www/upload'); // s'assure qu'il y a un fichier au minimum, 3 au maximum $element->addValidator('Count', false, array('min' => 1, 'max' => 3)); // Limite à 100K $element->addValidator('Size', false, 102400); // seulement des JPEG, PNG, et des GIF $element->addValidator('Extension', false, 'jpg,png,gif'); // définit 3 éléments fichiers identiques $element->setMultiFile(3); $form->addElement($element, 'foo');
Vous avez maintenant 3 éléments d'upload de fichier identiques
avec les mêmes paramètres. Pour obtenir le nombre de fichiers multiples
défini, appellez simplement
getMultiFile()
.
Eléments de fichier dans un sous formulaire
Quand vous l'utilisez dans des sous formulaires, vous devez définir des noms uniques. Par exemple, si vous nommez un élément fichier "file" dans le subform1, vous devez un nom différent à tout autre élément fichier dans subform2.
Si il y a deux éléments fichier portant le même nom, le second élément n'est pas affiché ou soumis.
De plus, les éléments fichiers ne sont pas affichés au sein du sous formulaire. Donc lorsque vous ajouter un élément fichier dans un sous formulaire, l'élément sera affiché dans le formulaire principal.
Afin de limiter, vous pouvez spécifier la taille maximum d'un fichier en définissant
l'option MAX_FILE_SIZE
sur le formulaire. Quand vous définissez
cette valeur en utilisant la méthode
setMaxFileSize($size)
, elle sera affiché avec l'élément
fichier.
$element = new Zend_Form_Element_File('foo'); $element->setLabel('Uploadez une image:') ->setDestination('/var/www/upload') ->addValidator('Size', false, 102400) // limit to 100K ->setMaxFileSize(102400); // limite la taille de fichier coté client $form->addElement($element, 'foo');
MaxFileSize et Eléments fichier multiple
Quand vous utilisez des éléments fichiers multiples dans votre formulaire
vous devez définir MAX_FILE_SIZE
seulement une fois.
La redéfinir écrasera la valeur précédente.
Notez que c'est aussi le cas lorsque vous utilisez des formulaires multiples.
Les éléments cachés injectent des données qui doivent être soumises, mais pas manipulées
par l'utilisateur. Zend_Form_Element_Hidden
remplit cette tâche
avec le helper de vue 'formHidden'.
Cette élément fournit une proctection contre les attaques CSRF sur les formulaires, en s'assurant que les données sont soumises par la session utilisateur qui a générée le formulaire et non par un script malveillant. La protection est réalisée en ajouté un élément de hachage au formulaire et en le vérifiant lors de la soumission du formulaire.
Le nom de l'élément de hachage doit être unique. Nous recommandons d'utiliser
l'option salt
pour l'élément - deux hachages ayant le même nom
mais des salt différent ne causeront pas de collision :
$form->addElement('hash', 'no_csrf_foo', array('salt' => 'unique'));
Vous pouvez définir le salt ultérieurement en utilisant la méthode
setSalt($salt)
.
En interne, l'élément stocke un identifiant unique en utilisant
Zend_Session_Namespace
, et le vérifie lors de la soumission
(en vérifiant que le TTL n'a pas expiré). Le validateur 'Identical' est ensuite
utilisé pour s'assurer que le hachage soumis correspond au hachage stocké.
Le helper de vue 'formHidden' est utilisé pour rendre l'élément dans le formulaire.
Des images peuvent être utilisées comme éléments de formulaires, et vous pouvez utiliser ces images en tant qu'éléments graphiques sur les boutons de formulaires.
Les images ont besoin d'une image source. Zend_Form_Element_Image
permet de la spécifier en utilisant l'accesseur setImage()
(ou la clé de configuration 'imageValue'). Quant la valeur définie pour l'élément
corresponde à imageValue
, alors l'accesseur
isChecked()
retournera TRUE
.
Les éléments image utilise le
décorateur Image
pour le rendu, en plus des décorateur standard Errors,
HtmlTag et Label. Vous pouvez spécifier une balise en option au décorateur
Image
qui entourera l'élément image.
Souvent, vous pouvez avoir un ensemble de case à cocher apparenté, et vous souhaitez grouper ces résultat. Cela ressemble beaucoup à Multiselect, mais au lieu que ce soit une liste déroulant, vous avez besoin d'afficher des paires case à cocher/valeur.
Zend_Form_Element_MultiCheckbox
rend cela simple
comme bonjour. Comme tous les éléments qui étendent l'élément de base Multi,
vous pouvez spécifier une liste d'options et les valider simplement à l'aide
de cette même liste. Le helper de vue 'formMultiCheckbox' s'assure qu'elles
seront retournées dans un tableau lors la soumission du formulaire.
Par défaut, cet élément enregistre un validateur InArray
qui effectue la validation à l'aide des clés du tableau d'options enregistrées.
Vous pouvez désactiver ce comportement, soit en appellant
setRegisterInArrayValidator(false)
, soit en passant
une valeur FALSE
à la clé de configuration
registerInArrayValidator
.
Vous pouvez manipuler les diverses options de case à cocher en utilisant les méthodes suivantes :
-
addMultiOption($option, $value)
-
addMultiOptions(array $options)
-
setMultiOptions(array $options)
(écrase les options existantes) getMultiOption($option)
getMultiOptions()
removeMultiOption($option)
clearMultiOptions()
Pour marquer les éléments cochés, vous devez passer un tableau de valeur à
setValue()
. Ce qui suit cochera les valeur "bar"
et "bat":
$element = new Zend_Form_Element_MultiCheckbox('foo', array( 'multiOptions' => array( 'foo' => 'Foo Option', 'bar' => 'Bar Option', 'baz' => 'Baz Option', 'bat' => 'Bat Option', ) )); $element->setValue(array('bar', 'bat'));
Notez que même en définissant une valeur unique vous devrez passer un tableau.
Les éléments select
XHTML autorisent un attribut
'multiple', indiquant que plusieurs options peuvent être sélectionné pour la soumission
du formulaire, au lieu d'une seule habituellement.
Zend_Form_Element_Multiselect
étend
Zend_Form_Element_Select,
et définit l'attribut multiple
à 'multiple'. Comme les autres classes qui
hétite la classe de base
Zend_Form_Element_Multi
, vous pouvez manipuler les options
du select en utilisant :
-
addMultiOption($option, $value)
-
addMultiOptions(array $options)
-
setMultiOptions(array $options)
(écrase les options existantes) getMultiOption($option)
getMultiOptions()
removeMultiOption($option)
clearMultiOptions()
Si un adapteur de traduction est enregistré au niveau du formulaire et/ou de l'élément, les valeurs des options seront traduites dans le cadre de l'affichage.
Par défaut, cette élément utilise un validateur InArray
qui effectue sa validation à partir des clés de tableau des options enregistrées.
Vous pouvez désactiver ce comportement, soit en appellant
setRegisterInArrayValidator(false)
, ou en passant une valeur
FALSE
à la clé de configuration
registerInArrayValidator
.
Les éléments mot de passe sont fondamentalement des éléments texte normaux -- à l'exception du fait que vous ne voulez pas que le mot de passe soumis soit affiché dans les messages d'erreurs ou lorsque le formulaire est affiché à nouveau.
Zend_Form_Element_Password
effectue cela en appellant
setObscureValue(true)
sur chaque validateur (s'assurant
ainsi que le mot de passe est dissimulé dans les messages d'erreur de validation),
et utilise le helper de vue 'formPassword' qui n'affiche pas la valeur qui lui est
passé).
Les éléments radio vous permettend de spécifier plusieurs options, parmi
lesquelles vous n'avez besoin que d'une seule. Zend_Form_Element_Radio
étend la classe de base Zend_Form_Element_Multi
,
vous permettant ainsi de spécifier un nombre indéfini d'options, et utilise
ensuite le helper de vue formRadio
pour les afficher.
Par défaut, cette élément utilise un validateur InArray
qui effectue sa validation à partir des clés de tableau des options enregistrées.
Vous pouvez désactiver ce comportement, soit en appellant
setRegisterInArrayValidator(false)
, ou en passant une valeur
FALSE
à la clé de configuration
registerInArrayValidator
.
Comme tous les éléments étendant la classe de base Multi element, les méthodes suivantes peuvent être utilisé pour manipuler les options radio affichées :
-
addMultiOption($option, $value)
-
addMultiOptions(array $options)
-
setMultiOptions(array $options)
(écrase les options existantes) getMultiOption($option)
getMultiOptions()
removeMultiOption($option)
clearMultiOptions()
Les boutons de mise à zéro sont typiquement utilisé pour vider un formulaire, et ne font pas partie des données soumises. Cela dit, comme ils remplissent un rôle dans l'affichage, ils sont inclus dans les éléments standards.
Zend_Form_Element_Reset
étend Zend_Form_Element_Submit.
Ainsi, le label est utilisé pour l'affichage du bouton et sera traduit, si un
adapteur de traduction est présent. Il utilise seulement les décorateurs
'ViewHelper' et 'DtDdWrapper', puisqu'il ne devrait jamais y avoir de messages
d'erreur pour ces éléments, le label ne sera pas non plus nécessaire.
Les listes d'options sont une manière habituelle de limiter des choix spécifiques.
Zend_Form_Element_Select
vous permet de les générer
rapidement et facilement.
Par défaut, cette élément utilise un validateur InArray
qui effectue sa validation à partir des clés de tableau des options enregistrées.
Vous pouvez désactiver ce comportement, soit en appellant
setRegisterInArrayValidator(false)
, ou en passant une valeur
FALSE
à la clé de configuration
registerInArrayValidator
.
Comme il étend l'élément de base Multi, les méthodes suivantes peuvent être utilisées pour manipuler les options du select :
-
addMultiOption($option, $value)
-
addMultiOptions(array $options)
-
setMultiOptions(array $options)
(écrase les options existantes) getMultiOption($option)
getMultiOptions()
removeMultiOption($option)
clearMultiOptions()
Zend_Form_Element_Select
utilise le helper de vue
'formSelect pour la décoration.
Les boutons Submit sont utilisé pour soumettre un formulaire. Vous pouvez
utiliser plusieurs boutons submit ; vous pouvez utiliser le bouton utilisé
pour soumettre le formulaire afin de décider quelle action effectuer avec
les données soumises.
Zend_Form_Element_Submit
rend cette décisions simple,
en ajoutant une méthode isChecked()
method ; puisqu'un
seul élément bouton sera soumis par le formulaire, après avoir rempli ou validé
le formulaire, vous pourrez appeller cette méthode sur chacun des boutons submit
afin de déterminer lequel a été utilisé.
Zend_Form_Element_Submit
utilise le label comme "value"
du bouton submit, il sera traduit si un adapeur de traduction est présent.
isChecked()
vérifie la valeur soumises avec
le label pour déterminer si le bouton a été utilisé.
Les décorateurs ViewHelper et DtDdWrapper sont utilisé pour rendre cet élément. Aucun décorateur de label n'est utilisé, puisque le label du bouton est utilisé lors du rendu de l'élément ; de plus, vous n'associerez aucune erreurs avec l'élément submit.
De loin le type d'élément de formulaire le plus répandu est l'élément text,
celui ci autorise des saisies de texte limité ; c'est un élément idéal pour
la plupart des saisies de données. Zend_Form_Element_Text
utilise simplement le helper de vue 'formText' pour afficher l'élément.
Les Textareas sont utilisé lorsque de grandes quantités de texte sont
attendues, et ne limite pas la quantité de texte soumise (si ce n'est la
taille limite fixée par votre serveur ou PHP).
Zend_Form_Element_Textarea
utilise le helper de vue
'textArea' pour afficher ces éléments, et place la valeur comme contenu de
l'élément.