Присвойте переменные дочернему шаблону в теге {% include %} Django

У меня есть этот код (который не дает мне ожидаемого результата)

#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>

дочерний шаблон:

#subject_file_upload.html
    <form action="." method="post" enctype="multipart/form-data">{% csrf_token %}
        {{ form.as_p }}
        <input type="submit" value="submit">
    </form>

и мой взгляд

#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))

Приведенный выше код создает HTML так, как я хочу, но форма не обновляет базу данных.

НО,

Если я пропущу средний шаблон и сразу перейду к форме загрузки, он будет работать нормально:

#subject_content.html
{% block main-menu %}
    {% include "subject_file_upload.html" %}
{% endblock %}

Помогите, пожалуйста, заставить его работать со средним шаблоном. Я хочу сделать это, потому что я не хочу набирать один и тот же код более одного раза.

1 ответ

Решение

Как предложил @Besnik, все довольно просто:

{% include "subject_file_upload.html" with form=form foo=bar %}

Документация дляinclude упоминает об этом. Также упоминается, что вы можете использовать only отображать шаблон только с заданными переменными, не наследуя никаких других переменных.

Спасибо @ Бесник

Другие вопросы по тегам