ビュー.py
def what(request):
user = request.user
report = Report.objects.get(user=user.id)
reportnotesform=ReportNotes(instance=report)
reportform = ReportForm(instance=report)
typeList = Types.objects.filter(user=user, is_active=True,parent_type_id=None)
list = []
for type in typeList:
if not type.parent_type_id:
list.append(type)
subtype = Types.objects.filter(parent_type_id=type.id, is_active=True)
for subtypes in subtype:
list.append(subtypes)
if request.method == 'POST':
ReportType.objects.filter(report=report).delete()
checked_ones = [unicode(x) for x in subtype if unicode(x) in request.POST.keys()]
reportnotesform=ReportNotes(request.POST,instance=report)
if reportnotesform.is_valid():
report=reportnotesform.save(commit=False)
report.user=request.user
report.save()
for entry in checked_ones:
r = ReportType()
r.report = report
r.title = entry
r.save()
return redirect('/member/where/')
checked_ones = [x.title for x in ReportType.objects.filter(report=report)]
return render(request, 'incident/what.html',
{
'newreport_menu': True,
'typeList':list,
'checked_ones':checked_ones,
# 'typelist': typelist,
'ReportNotes':reportnotesform,
'ReportForm':reportform
})
models.py
class ReportType(models.Model):
report = models.ForeignKey(Report)
title = models.CharField('Incident Type', max_length=200)
テンプレート
{% for type in typeList%}
{% if type.parent_type_id == None %}
<h1>{{type.title}}</h1>
{% else %}
<p><input type="checkbox">{{type.title}}</input></p>
{% endif %}
{% endfor %}
モデルフォームを使用してチェックボックスを動的に表示しています。
これは、データベースから値を取得して表示している私のビューです.typelistオブジェクトによってフィルタリングされた値は、チェックボックスとともに値を表示する必要があります.typesオブジェクトの場合、問題ではありません.djangoでそれを行う方法はあります.