web-dev-qa-db-ja.com

{%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 %}

真ん中のテンプレートで動作するようにしてください。同じコードを2回以上入力したくないので、これを行います。

75
Vor

@Besnikが提案したように、それは非常に簡単です:

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

includeのドキュメント はこれに言及しています。また、onlyを使用して、他の変数を継承せずに、指定された変数のみでテンプレートをレンダリングできることにも言及しています。

ありがとう@Besnik

179
Vor