だから、TagStatusモデルがあります。 ModelFormを作成しようとしています。ただし、私のフォームでは、非表示の入力に{{tag.name}}を入力する必要があります。私はドキュメントを調べてきましたが、タグフィールドを隠し入力にする方法がわかりません。おそらく、ModelFormを使用する方法ではありませんか?
models.py:
class TagStatus(models.Model):
user = models.ForeignKey(User, null=True, unique=True)
status = models.CharField(max_length=2, choices=tag_statuses)
tag = models.ForeignKey(Tag, null=True, blank=True)
def __unicode__(self):
return self.status
def save(self, *args, **kwargs):
super(TagStatus, self).save(*args, **kwargs)
class TagStatusForm(modelForm):
class Meta:
model = TagStatus
fields = ('status','tag')
widgets = {
'select': Select,
'tag': ???
}
Django views.py:
@login_required
def tags(request):
all_tags = Tag.objects.all()
context = base_context(request)
if request.method == 'POST':
if 'status_check' in request.POST:
status_form = TagStatusForm(request.POST)
#if request.is_ajax():
if status_form.is_valid():
status_form.save()
response = simplejson.dumps({"status": "Successfully changed status"})
else:
response = simplejson.dumps({"status": "Error"})
return HttpResponse (response, mimetype='application/json')
status_form = TagStatusForm()
context['status_form'] = status_form
context['all_tags'] = all_tags
return render_to_response('tags/tags.html', context, context_instance=RequestContext(request))
テンプレート:
{% for tag in all_tags %}
....
<form class="Nice" id="status-form" method="POST" action="">
{% csrf_token %}
<input type="hidden" name="status_check" />
<input type='hidden' name="tag" value="{{ tag.name }}" />
{{ status_form.status }}
</form>
...
{% endfor %}
Django ModelFormを介して非表示の入力を行い、テンプレートを介して入力する方法を教えてください。
ModelFieldのフィールドを非表示フィールドにするには、HiddenInputウィジェットを使用します。 ModelFormは、すべてのフィールドに賢明なデフォルトウィジェットを使用します。オブジェクトの構築時にオーバーライドする必要があります。
class TagStatusForm(forms.ModelForm):
class Meta:
model = TagStatus
widgets = {'tag': forms.HiddenInput()}
Djangoの非表示フィールドをレンダリングする方法は3つ(AFAIK)あります-
1。通常forms.py
でフィールドを宣言できますが、テンプレートhtmlファイルでは{{ form.field.as_hidden }}
を使用します
2。 in forms.py
in hidden input widgetを直接使用します。
class MyForm(forms.Form):
hidden_field = forms.CharField(widget=forms.HiddenInput())
フィールドを非表示入力にすると、テンプレートにフィールドの値を入力できます。これで、非表示フィールドをレンダリングする準備ができました。
。同等の正規フォーム(このナゲットを共有してくれた@Modelesqに感謝)。ここでは、Djangoは関係しません。変更はHTMLテンプレートレベルで行われます。 <input type="hidden" name="tag" value="{{ tag.name }}" />
私はすべての入力を隠す方法を探していました:
class TagStatusForm(forms.ModelForm):
class Meta:
model = TagStatus
def __init__(self, *args, **kwargs):
super(TagStatusForm, self).__init__(*args, **kwargs)
for field in self.fields:
self.fields[field].widget = forms.HiddenInput()
一般的なクラスベースのビューでそれを行う方法を投稿しました here :
from Django.forms import HiddenInput
from Django.forms.models import modelform_factory
_patient_create_form = modelform_factory(
models.Patient,
fields=['name', 'caregiver_name', 'sex', 'birth_date',
'residence', 'country'],
widgets={'country': HiddenInput()})
class PatientCreate(LoginRequiredMixin, UserOrgRequiredMixin, CreateView):
form_class = _patient_create_form
template_name = 'healthdbapp/patient_form.html'