Académique Documents
Professionnel Documents
Culture Documents
TP Révision Forms
TP Révision Forms
Exercice 4. Test du premier formulaire Nous pouvons a présent apprécier le résultat! Lancez vatre serveur ./manage.py runserver Ft disigez-vous & adresse http://localhost :8060/contacts/ Vous devez abtenir un formulaire (mocha) avec les libellés de la classe Contact. Notre formulaire html utilisant des balises ‘
a été automatiquement généré! Pour
Vinstent il reste encore assez simple, mais nous allons voir que nous allons pouvoir trés
vite tout personnaliser et avoir un bien meilleur rendu! D'autres options d'affichage telles
que ‘as_ul’ et ‘as table auraient pu étre utilisées,
Pour plus d'informations sur les forms, voir la doc oficielle : https: //docs.djangoproject.
con/fr/3.1/topics/forms/ECOLE MAROCAINE DES
SCIENCES DE LINGENIEUR
Exercice 5. Création d'un formulaire & la main (sans Model)
Mais avant cela, nous allons nous intéresser & la création de formulaires sans utiliser de
modéle, directement avec le module forms de Django ! Pour ceux qui souhaitent approfondir
la création de formulaires a partir de modeles, voir la documentation officielle, Créons
maintenant notre formulaire ContactForn2 sans utiliser de modele, en modifiant comme
suit le views.py de lapplication ‘myform’
1 from django.shortcuts import render
from django. forms import ModelForm
from models import Contact
# avec ModelForm
class ContactForm("odelForm) :
class Meta:
model = Contact
fields = (‘name', ‘firstname’, ‘email’, ‘message‘)
from django import forms
class ContactForm2 (forms. Form) :
name ~ forms .CharField(max_length-200)
firstname = forms .CharField(max_length=200)
email = forms .FmailField(max_length=290)
message = forns.CharField(max_length=1000)
3
4
5
6
7
8
9
10
1
12
13 # Sans ModelForn
14
15
16
7
18
19
20
def contact (request) =
21 contact_form = ContactForm()
22 contact_forn2 = ContactForn2 ()
23 return render(request,' contact.html", {'myform/
contact_form' : contact_form, ‘contact form2’ :
contact_form2})
On inclut directement le module ‘forms’ de django et on crée une classe ‘ContactForm2"
dérivant de Form et non de ModelForm cette fois-ci. On crée ainsi notre classe, ce qui res-
semble sensiblement & la déclaration de notre modéle. Puis on crée un objet contact_form2
dans notre fonction et on le passe en donnée de notre template, Maintenant éditez votre
fichier contact.html de cette fagon =
1 {{contact_forn.as_p }}
2
3 {{ contact_form2.as_p })
On obtient donc deux formulaires identiques créés de deux facons différentes !ECOLE MAROCAINE DES
SCIENCES DE VINGENIEUR
Exercice 6. Personnalisation des formulaires et vérifications
Intéressons-nous maintenant a la personnalisation de ces formulaires avant de comprendre
comment les utiliser et gérer leur validation. Les formulaires de type ModelForm cinsi
que ceux de type Farm peuvent contenir de nombreuses options de personnalisation. On.
peut tout de suite remarquer certaines options telles que : required, label, initial, widget,
help_text, error_messages, validator, localize required va spécitier si le champ du formu-
laire peut tre ignoré ou nan, par défaut tous les champs sont requis. Cela implique que si
utilisateur valide le formulaire avec des champs & vide (" ou None), une erreur sera levée
Pour illustrer cela, voici ce que donnent les tests suivants aprés avoir ouvert une console
python en mode django et avoir importé Le module forms =
Quvrons un shell et testons
>»>from django inport forms
>>> f-forms .CharFieldQ,
>>> f.clean('foo')
"foo"
>>> £.clean('')
ValidationError: ['This field is required.
>>> f = forms. CharField(required=False)
>>> £.clean (None)
BS eevsuswns
ValidationError: ['This field is required."]
Nous simutons ict la vérification de formulaire avec la méthode clean (). Comme vous pouvez
le constater, une erreur est bien levée si nous passons une cheine vide ou None notre
champ. label va permettre de réécriro la facon dont le label du champ est affiché, par
défaur, cela prend le nom de a variable et lui ajoute une majuscule a la premiare Lettre et
remplace tous les underscores par des espaces. Exemple :
1 >>>class CommentForm(forms. Form) :
2s name = forms .CharField(labe:
: url
=False)
: comment = forms .CharField()
"Your name")
forms .URLField(label="Your Web site’, required
4
3
6 >>> £ = ConmentForm()
7 >>> print (f)
& ECOLE MAROCAINE DES
SCIENCES DE LINGENIEUR
12
13.
durl" />
d_comment ">Comment :
Vous voyez également qu‘ici on affiche notre ‘form’ sons utiliser d'option daffichage, il est
done affiché par défaut en utilisant une table, Pour plus de commodité, on aurait pu rajouter
option ‘euto_id’ a ‘False’, ce qui aurait pour effet de désactiver la création dune balise
label, et générerait ceci
1 >>5£ = ComnentForm(auto_id=False)
2 >>> print (4)
3
14
15
16
5
8 Your Web site:
6
7
initial va permettre de donner des valeurs par défaut 4 vas champs, exemple
1 >s>elass CommentForm(forms .Forn):
es name = forms.CharField(initial="Your name')
Sy naa url = forms.URLField(initial="http://')
Ao a conment = forms.CharField()
5 >>> £ = ConmentForm(auto_id=False)
6 >>> print =
7 Conment :
9
10
url" value="http://" />ECOLE MAROCAINE DES
SCIENCES DE LINGENIEUR
Nous nous arréterons & ces trois options pour le moment et verrons les autres dans des cas
plus poussés. Par contre il est tres intéressant de se pencher sur Loption ‘widget' car elle
va vous permettre de réaliser trés facilement des champs spécifiques.
1 django import forms
2 class CommentForm(forms. Form) :
3 name = forms. CharFieldQ,
4 url = forms. URLFieldQ
5 comment = forms .CharField(widget=forms. Textarea)
Ou bien :
1 from django. forms. fields import DateField, ChoiceField,
MultipleChoiceField
2 from django.forms.widgets import RadioSelect,
CheckboxSelectMultiple
from django. forms.extras.widgets import SelectDateWidget
3
4
5 BIRTH_YEAR_CHOTCES
6 GENDER_CHOICES = (('m', ‘Male'), ('f", ‘"Female'))
7 FAVORITE _COLORS_CHOICES = (('blue', ‘Blue")
8 Cgreen', ‘Green'),
9
10
1
12
1999", *2000", *2061")
Cblack', 'Black'))
class SimpleForm(forms .Forn) :
birth_year = DateField(widget-SelectDatewidget (years=
BIRTH_YEAR_CHOICES))
13 gender = ChoiceField(widget=RadioSelect , choices=
GENDER_CHOICES)
14 favorite_colors = forns.MultipleChoiceField (required-False
5 widget=CheckboxSelectMultiple, choices=
FAVORITE_COLORS_CHOICES)
Essayez-les |
Un petit demier
1 class CommentForm(forms . Form):
2 name = forms. CharField(
3 widget=forms.TextInput (attrs={' class": ‘special
pr
4 url = forms. URLFieldQ
5 comment = forms .CharField(
6 widget=forns .TextInput (attrs={'size':'49'}))ECOLE MAROCAINE DES
SSCIENCES DE LINGENIEUR
Ce qui donnera :
£ = Comment Form(auto_id=False)
>>> f.as_tableQ
Name:
8 Comment :
Name:
eNO eeNS
comment” size="40"/>
Nihésitez pas & parcourir les différents types de widgets dans la doc de django et & les
essayjer pour découvrir ce qu’ils produisent
Exercice 7. ModelForms
Anoter que vous pouvez également utiliser les widgets avec des Form venant de Modéles :
Exemple
‘name’: Textarea(attrs={'cols': 80, ‘rows’: 20}),
1 from django.forms import ModelForm, Textarea
2
3 class AuthorForm(ModelForm) :
4 class Meta:
5 model = Author
6 fields = ('name', ‘title’, "birth date’)
7 widgets = {
8
9
+
Modifier les formulaires de application myform en utilisant les informations ci-dessus. Tes-
ter par exemple en modifiant la vue de myform comme ci-dessous
from django.shortcuts import render
from django. forms import ModelForm, Textarea
from -models import Contact
from django import forms
class ContactForm(ModelForm):
eVoONsuns
class Meta:COLE MAROCAINE DES
SCIENCES DE UINGENIEUR
9 model = Contact
10 fields =('nane,'firstaname, ‘email’, 'message')
n widgets
2
B ‘message’: Textarea(attrs={'cols':60, 'rows':16}),
14
15 }
16
17 class ContactForm2 (forms. Form):
18 name = forms. CharField(max_length=200, initial="votre nom
",Label="nom")
19 firstname = forms.Charfield(max_length=200,initial="
votre prenon", label="prenom")
20 email = forms. EmailField(max_length=200, label="mel")
a message = forms. CharField(widget=forms.Textarea(attrs={'
cols':60, ‘rows’ :10}))
2
B
24 def contact (request):
B
2% contact_form = ContactForm()
27 ~~‘ #return render (request, ‘myform/conctact -html', {*
contact_form':contact_form})
2B
29 contact_form2 = ContactForm2 ()
30 © return render (request , ‘my form/conctact . html
contact_form':contact_form, 'contact_forn2
contact_form2})
Essayer d'autres possibilités.
Enfin, nous allons nous intéresser a la validation des formulaires, comment gérer das mes-
sages pour la page suivante et comment travailler avec ceux-ci. Nous allons reprendre le
fichier views py de notre application ‘myform’ et remplacer son contenu par celui-ci
from django.shortcuts import render, redirect
from django.forms import ModelForm, Textarea
from -models import Contact
from django import forms
from django.urls import reverse
from django.http import HttpResponse
from django.contrib import messages
eeu ausuns
class ContactForm(HodelForm):10
n
2
B
4
6
16
7
18
19
20
2
22.
2B
24
2B
26
a
2B
29
30
a
32
B
34
5
36
a
ECOLE MAROCAINE DES
‘SCIENCES DE LINGENIEUR
def _init__(self, “args, **kwargs):
super (ContactForm, self)._init__(*args, **kwargs)
self. fields['name'].label = "Nom
self. fields['firstname'].label =
self. fields['email'].label = "mél
class Meta:
model = Contact
Fields = ('name', ‘firstname’, essage ')
widgets = {'message': Textarea(attrs={'cols': 60, ‘rows’
16}).4
Prenom”
def contact (request):
# on instancie un formulaire
form = Contact Form()
# on teste si on est bien en validation de formulaire (
POST)
4f request.method == "Post":
# Si oui on récupére les données postées
form = Contact Form(request . POST)
# on vérifie la validité du formulaire
if form.is_validQ:
new_contact = form. saveQ
# on prépare un nouveau message
messages.success(request, ‘Nouveau contact '+
new_contact.name+' '+new_contact. email)
return redirect(reverse("detail', args=[
new_contact.pk] })
context = {'pers’: new_contact}
return render(request,'detail.html', context)
# Si méthode GET, on présente le formulaire
context = {'form': form}
return render(request,‘contact html', context)
‘Avec une nouvelle vue detail
1
2.
3
def detail(request, cid):
contact = Contact.objects.get(pk=cid)
return HttpResponse(’ Nouveau contact ‘+contact.name+"
contact .email)
+
et un template detail html
2
1 {% extends "base. html" x}
{% load static %}
10ECOLE MAROCAINE DES
SCIENCES DE LINGENIEUR
3 {% block title x}
4 Contacts
5 {% endblock %}
6 {% block header %}
a {% if messages X}
8 {% for message in nessages x}
9 Url :
{{message}}
10 {% endfor %}
n 1% endif %}
2 {% endblock %}
3
14 {% block content %}
6
16
0 {% endblock %}
Et nous allons définir une nouvelle url pour la page ‘detail
Pour ce faire on modifiera les fichiers urls. py de Gestion Taches et myform. Pour tester, il
nous faudra également modifier le template contact html
1 {% extends "base.html" %}
{% load static x}
{% block title x}
Nouveau Contact
{% endblock %}
{% block navtitle %}
Nouveau Contact
{% endblock %}
3
4
5
6
7
8
9
10
n {% block content%}
12
20 {% endblock %}
12