J'ai ce code (qui ne me donne pas le résultat attendu)
#subject_content.html
{% block main-menu %}
{% include "subject_base.html" %}
{% endblock %}
#subject_base.html
....
....
<div id="homework" class="tab-section">
<h2>Homework</h2>
{% include "subject_file_upload.html" %}
</div>
modèle enfant:
#subject_file_upload.html
<form action="." method="post" enctype="multipart/form-data">{% csrf_token %}
{{ form.as_p }}
<input type="submit" value="submit">
</form>
et ma vue
#views.py
@login_required
def subject(request,username, subject):
if request.method == "POST":
form = CarsForm(request.POST, request.FILES)
if form.is_valid():
form.save()
return HttpResponseRedirect("/")
form = CarsForm()
return render_to_response('subject_content.html', {'form':form}, context_instance=RequestContext(request))
Le code ci-dessus crée le code HTML de la manière que je souhaite, mais le formulaire ne met pas à jour la base de données.
MAIS,
Si je saute le modèle du milieu et que je vais directement au formulaire de téléchargement, cela fonctionne bien:
#subject_content.html
{% block main-menu %}
{% include "subject_file_upload.html" %}
{% endblock %}
Aidez-moi s'il vous plaît à le faire fonctionner avec le modèle moyen. Je veux faire cela, parce que je ne veux pas taper le même code plus d'une fois.
Comme l'a suggéré @Besnik, c'est assez simple:
{% include "subject_file_upload.html" with form=form foo=bar %}
Le documentation pour include
le mentionne. Il est également mentionné que vous pouvez utiliser only
pour rendre le modèle avec les variables fournies uniquement, sans hériter d'autres variables.
Merci @Besnik