私はdjangoを初めて使用し、非常に単純なことをするのに苦労しています。私はModelForm
次のモデルのために持っています:
class Queries(models.Model):
user_id=models.CharField(max_length=200)
query=models.CharField(max_length=200)
そして、私はユーザーに次のことを行うのに役立つ簡単なフォームを示しています。
- ユーザーが質問します
質問が処理されます(データベースクエリは質問に基づいて生成されます)
次に、クエリ結果が同じページのフォームのすぐ下に表示されます。
これは私のviews.pyがどのように見えるかです:
from django.http import HttpResponse
from django.shortcuts import get_object_or_404, render
from basicapp.models import QueryForm
def index(request):
form=MyForm()
real_form=form.getForm(request)
response=form.response
return render(request,'basicapp/index.html',{
'form': real_form,
'response':response,
})
class MyForm:
response=''
def getForm(self,request):
form = QueryForm(request.POST)
if form.is_valid():
response=form.cleaned_data['query']
form.save()
return form
今のところ私は簡単なことを試しています。フォームのクエリフィールドの値を取得してページに送り返そうとしています。これまでのところ失敗しています。これはindex.htmlです:
<form action=" " method="post">{% csrf_token %}
{{ form }}
<p>{{response}}</p>
<input type="submit" value="Submit" />
</form>
これができれば、クエリはそれほど難しくないと思います。フォームは正常に機能しており、データはデータベースに保存されています。フォームの送信後、response
からの文字列のみviews.py
を内部で取得できませんでした。index.html
手伝ってもらえますか?
編集:index.html
ホフの答えに基づいてフォローしてみました:
<form id="myForm" action=" " method="get">{% csrf_token %}
{{ form }}
<input type="submit" value="Submit" />
</form>
<div id="response">
</div>
<script language="JavaScript">
$(document).ready(function() {
$("#myForm").submit(function() { // catch the form's submit event
$.ajax({ // create an AJAX call...
data: $(this).serialize(), // get the form data
type: $(this).attr('GET'),
success: function(response) { // on success..
$("#response").html(response); // update the DIV
}
});
return false;
});
});
</script>
まだ運がない:(