モデルに裏打ちされていないテンプレートをテンプレートに含めることはできますか。ビューに自分のリクエストPOSTを生成するために必要なデータだけを保存する必要はありません。
テンプレート-テキストフィールドを持つフォーム。表示-フォームからデータを取得し、別のリクエストを生成します。
フロー->フォーム送信は、ビューを呼び出すURLに移動します。
def form_handle(request):
if request.method=='POST'
form = request.POST
#blah blah encode parameters for a url blah blah
#and make another post request
しかし、これはcsrfトークンのみをフォーム変数に入れます。 form_handleビューでテンプレートのこれらのテキストフィールドにアクセスする方法はありますか?
私はモデルでそれを行う方法を知っていますが、これを理解できませんでした!
はい。これは非常に可能です。 Formオブジェクト で読むことができます。モデルにバインドされておらず、すべてのフォーム属性を明示的に宣言する必要があることを除いて、ModelForm
を処理するのと同じ方法になります。
def form_handle(request):
form = MyForm()
if request.method=='POST':
form = MyForm(request.POST)
if form.is_valid():
cd = form.cleaned_data
#now in the object cd, you have the form as a dictionary.
a = cd.get('a')
#blah blah encode parameters for a url blah blah
#and make another post request
#edit : added ": " after if request.method=='POST'
そして
class MyForm(forms.Form): #Note that it is not inheriting from forms.ModelForm
a = forms.CharField(max_length=20)
#All my attributes here
テンプレート内:
<form action="{% url form_handle %}" method="POST">{% csrf_token %}
{{form.as_p}}
<button type="submit">Submit</button>
</form>