Zend_Form démarrage rapideCe guide rapide couvre les bases de la création, de la validation, et du rendu des formulaires
Zend_Form.Créer un objet de formulaireInstanciez simplement un objet Zend_Form :Pour des usages avancés, vous voudriez probablement dériver Zend_Form, mais pour les
formulaires simples, vous pouvez créez un formulaire depuis une instance de Zend_Form.Vous pouvez spécifier (c'est une bonne idée) l'action et la méthode d'envoi du formulaire grâce à
setAction() et setMethod() :setAction('/resource/process')
->setMethod('post');
]]>Le code ci-dessus indique au formulaire d'être envoyé vers l'URL "/resource/process" avec la méthode HTTP
POST. Ceci va impacter le rendu du formulaire (la balise <form>).Il est possible d'assigner les attributs HTML supplémentaires à la balise <form> via la
méthode setAttrib() ou encore setAttribs(). Par exemple, indiquons un attribut "id" au
formulaire :setAttrib('id', 'login');
]]>Ajouter des éléments au formulaireUn formulaire ne sert à rien sans éléments. Le composant Zend_Form est fourni avec un
ensemble d'éléments qui rendent du code XHTML via les aides de Zend_View. Voici ces aides :buttoncheckbox (ou plusieurs checkboxes avec multiCheckbox)hiddenimagepasswordradioresetselect (régulier ou à selection multiple)submittexttextareaVous avez 2 manières de procéder pour ajouter les éléments au formulaire : instanciez vous même les objets
des éléments, ou passer le type d'élément à Zend_Form, qui va alors créer le bon objet pour
vous.Quelques exemples :addElement(new Zend_Form_Element_Text('username'));
// Passage d'un texte décrivant le futur objet élément, à Zend_Form :
$form->addElement('text', 'username');
]]>Par défaut, ces éléments n'ont ni validateurs, ni filtres. Vous devrez donc ajoutez des validateurs et/ou
des filtres, manuellement. Ceci est possible soit (a) avant de passer l'élément au formulaire, (b) via les
options de configuration passés lors de la création de l'élément, ou (c) en récupérant l'objet déjà enregistré,
depuis le formulaire, et en le configurant ensuite.Voyons comment passer un validateur à un élément dont nous créons l'objet. On peut passer soit l'objet
Zend_Validate_*, soit une chaîne le décrivant :addValidator(new Zend_Validate_Alnum());
// Passage du nom du validateur:
$username->addValidator('alnum');
]]>En utilisant la technique de passage par le nom, vous pouvez ajouter un tableau d'options à passer au
constructeur de l'objet validateur. Ceci se fait en troisième paramètre :addValidator('regex', false, array('/^[a-z]/i'));
]]>(Le second paramètre permet d'indiquer au validateur s'il doit briser la chaîne de validation ou non. Par
défaut, false : ce n'est donc pas le cas.)Vous pouvez avoir besoin de spécifier qu'un élément est requis. Ceci peut être fait en utilisant un
accesseur ou en passant une option à la création de l'élément. Voici un exemple :setRequired(true);
]]>Lorsqu'un élément est requis, un validateur "NotEmpty" lui est ajouté, sur le dessus de sa pile de
validateurs.La gestion des filtres est très semblable à celle des validateurs. Voyons comment ajouter un filtre qui
retourne la donnée en minuscules :addFilter('StringtoLower');
]]>Finalement, la configuration complète de l'élément pourra ressembler à cela :addValidator('alnum')
->addValidator('regex', false, array('/^[a-z]/'))
->setRequired(true)
->addFilter('StringToLower');
// ou, de manière plus compacte:
$username->addValidators(array('alnum',
array('regex', false, '/^[a-z]/i')
))
->setRequired(true)
->addFilters(array('StringToLower'));
]]>Aussi simple que cela puisse paraître, cela peut très vite devenir fastidieux de répéter ces opérations
sur tous les éléments du formulaire. Reprenons le cas (b) d'au dessus : lorsque l'on crée un élément,
Zend_Form::addElement() agit comme une fabrique et on peut lui passer des options de configuration.
Par exemple, des validateurs ou des filtres. Essayons ceci :addElement('text', 'username', array(
'validators' => array(
'alnum',
array('regex', false, '/^[a-z]/i')
),
'required' => true,
'filters' => array('StringToLower'),
));
]]>Si vous vous apercevez que vous créez des éléments basés sur les mêmes options, étendre
Zend_Form_Element peut devenir une bonne option. Votre nouvelle classe configurera directement
vos objets.Rendre (visuellement) un formulaireRendre un formulaire est très simple. La plupart des éléments nécessitent les aides de vue
Zend_View pour être rendus. Ils ont donc besoin d'un objet de vue. Pour rendre un formulaire,
appelez sa méthode render() ou faites un echo devant l'objet.render($view);
// Supposant que setView() avec passage d'un objet Zend_View a été appelée avant :
echo $form;
]]>Par défaut, Zend_Form et les Zend_Form_Element vont essayer de récupérer l'objet
de vue depuis l'aide d'action ViewRenderer, ce qui signifie que vous n'aurez pas besoin de
spécifier un objet de vue manuellement si vous utilisez le système MVC de Zend Framework. Pour rendre un
formulaire dans une vue MVC, un simple echo suffit :form ?>
]]>Techniquement, Zend_Form utilise des "décorateurs" pour effectuer le rendu visuel. Ces
décorateurs peuvent remplacer le contenu, ou le placer avant ou après. Ils peuvent aussi introspecter l'élément
qui leur est passé. Ainsi, vous pouvez chaîner plusieurs décorateurs pour utiliser des effets visuels. Par
défaut, Zend_Form_Element combine quatre décorateurs pour s'afficher :addDecorators(array(
'ViewHelper',
'Errors',
array('HtmlTag', array('tag' => 'dd')),
array('Label', array('tag' => 'dt')),
));
]]>(Où <HELPERNAME> est le nom de l'aide de vue à utiliser, qui varie selon l'élément à rendre.)Les décorateurs par défaut (rappelés ci-dessus), produisent le rendu suivant :(Le formatage peut un peu changer.)Vous pouvez changer les décorateurs utilisés par un élément si vous voulez avoir un visuel différent ;
voyez la section sur les décorateurs pour plus d'informations.Le formulaire boucle sur ses éléments et entoure leur rendu d'une balise HTML <form>.
Cette balise prend en compte la méthode, l'action, et les éventuels attributs passés via
setAttribs().Les éléments sont bouclés dans l'ordre dans lequel ils sont ajoutés, ou, si votre élément possède un
attribut "order", celui-ci sera alors utilisé pour gérer sa place dans la pile des éléments :setOrder(10);
]]>Ou encore, à la création de l'élément via addElement() :addElement('text', 'username', array('order' => 10));
]]>Vérifier qu'un formulaire est valideAprès l'envoi du formulaire, il faut vérifier les valeurs que contiennent ses éléments. Tous les
validateurs de chaque élément sont donc interrogés. Si l'élément était marqué comme requis et que l'élément ne
reçoit aucune donnée, les validateurs suivants agiront sur une valeur null.D'où proviennent les données ? Vous pouvez utiliser $_POST ou $_GET, ou
n'importe quelle source de données (service Web par exemple) :isValid($_POST)) {
// succès!
} else {
// echec!
}
]]>Avec des requêtes AJAX, il arrive que l'on ait besoin de ne valider qu'un élément, ou un groupe d'élément.
isValidPartial() validera un formulaire partiel. Contrairement à isValid(), si une
valeur est absente, les autres validateurs ne seront pas interrogés:isValidPartial($_POST)) {
// Tous les éléments présents dans $_POST ont passé la validation
} else {
// un ou plusieurs éléments présent dans $_POST ont échoué
}
]]>La méthode processAjax() peut aussi être utilisée pour valider partiellement un formulaire.
Contrairement à isValidPartial(), cette méthode retournera les messages d'erreur de validation au
format JSON.En supposant que les validateurs aient passé, vous pouvez dès lors récupérer les valeurs filtrées depuis
les éléments :getValues();
]]>Si vous désirez les valeurs non filtrées, utilisez :getUnfilteredValues();
]]>Les statuts d'erreurVotre formulaire a échoué à l'envoi ? Dans la plupart des cas, vous voudrez rendre à nouveau le
formulaire, mais avec les messages d'erreur affichés :isValid($_POST)) {
echo $form;
// ou en assignant un objet de vue (cas non-MVC typiquement)
$this->view->form = $form;
return $this->render('form');
}
]]>Si vous voulez inspecter les erreurs, 2 méthodes s'offrent à vous. getErrors() retourne un
tableau associatif avec en clé le nom de l'élément et en valeur un tableau de codes d'erreurs.
getMessages() retourne un tableau associatif avec en clé le nom de l'élément, et en valeur un
tableau de messages d'erreurs (code=>message). Tout élément ne comportant pas d'erreur ne sera pas inclus
dans le tableau.Assembler le tout ensembleCréons un formulaire de d'authentification. Il aura besoin d'élément représentant :un nomun mot de passeun bouton d'envoiPour notre exemple, imaginons un nom composé de caractères alphanumériques uniquement. Le nom commencera
par une lettre, et devra faire entre 6 et 20 caractères de long, qui seront normalisés en lettres minuscules.
Les mots de passe feront 6 caractères minimum.Nous allons utiliser la puissance de Zend_Form pour configurer le formulaire et effectuer le
rendu :setAction('/user/login')
->setMethod('post');
// élément nom :
$username = $form->createElement('text', 'username');
$username->addValidator('alnum')
->addValidator('regex', false, array('/^[a-z]+/'))
->addValidator('stringLength', false, array(6, 20))
->setRequired(true)
->addFilter('StringToLower');
// élément mot de passe :
$password = $form->createElement('password', 'password');
$password->addValidator('StringLength', false, array(6))
->setRequired(true);
// Ajout des éléments au formulaire
$form->addElement($username)
->addElement($password)
// addElement() agit comme une fabrique qui crée un bouton 'Login'
->addElement('submit', 'login', array('label' => 'Login'));
]]>Il nous faut à présent un contrôleur pour gérer tout cela:view->form = $this->getForm();
$this->render('form');
}
public function loginAction()
{
if (!$this->getRequest()->isPost()) {
return $this->_forward('index');
}
$form = $this->getForm();
if (!$form->isValid($_POST)) {
// Validation en echec
$this->view->form = $form;
return $this->render('form');
}
$values = $form->getValues();
// les valeurs sont récupérées
}
}
]]>Le script de vue pour afficher le formulaire :Identifiez vous:
= $this->form ?>
]]>Comme vous le voyez sur le code du contrôleur, il reste du travail à faire une fois le formulaire validé.
Par exemple, utiliser Zend_Auth pour déclencher un processus d'identification.Utiliser un objet Zend_ConfigToutes les classes du composant Zend_Form sont configurables au moyen d'un objet
Zend_Config ; vous pouvez passer un objet Zend_Config au constructeur ou via la
méthode setConfig(). Voyons comment créer le formulaire ci-dessus, au moyen d'un fichier INI. Tout
d'abord, nous nous baserons sur une section "developement", et nos instructions devront être imbriquées afin de
refléter la configuration. Ensuite nous utiliserons un espace de nom "user" correspondant au contrôleur, puis un
"login" concernant le formulaire (ceci permet de ranger les données correctement dans le fichier INI) :Le constructeur du formulaire ressemblera alors à ceci :user->login);
]]>et tout le formulaire sera défini.ConclusionVous êtes maintenant capable de libérer la puissance de Zend_Form. Continuez de lire les
chapitres suivants pour utiliser ce composant en profondeur !