98

私はこのコードを持っています(期待した結果が得られません)

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

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

4

1 に答える 1

251

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

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

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

ありがとうございます

于 2012-07-24T21:36:13.557 に答える