我很难同时使用两种django脆皮。我有一个表单只是将新数据输入到我的应用程序中,另一个表单显示在引导程序模式中,供用户提供反馈。下面,我已经将我的模板剥离到了裸露的基础。
我有一个小组表格:
class Crispy_Group_Form(forms.ModelForm):
def __init__(self, *args, **kwargs):
self.helper = FormHelper()
# self.helper.form_tag = False
self.helper.form_class = 'form-horizontal'
self.helper.layout = Layout(
Fieldset(
'New Group',
Field('name', placeholder='Group Name'),
Field('notes', placeholder='Group Notes', rows='10', css_class='input-xxlarge'),
),
FormActions(
Submit('save_changes', 'Save changes', css_class="btn-primary"),
HTML(' | '),
Submit('cancel', 'Cancel'),
)
)
self.helper.form_id = 'id-Crispy_Group_Form'
self.helper.form_method = 'post'
super(Crispy_Group_Form, self).__init__(*args, **kwargs)
class Meta:
model = Group
exclude = ['slug']
和联系表格
class Crispy_ContactForm(forms.ModelForm):
def __init__(self, *args, **kwargs):
self.helper = FormHelper()
self.helper.form_class = 'form ajax'
self.helper.form_action = 'feedback'
self.helper.form_tag = False
self.helper.layout = Layout(
Fieldset(
'Contact Form',
Field('topic', placeholder='Topic', css_class='input-medium'),
Field('subject', placeholder='Subject', css_class='input-xlarge'),
Field('message', placeholder='Message', rows='5', css_class='input-xlarge'),
Field('sender', placeholder='Sender', css_class='input-xlarge'),
),
)
self.helper.form_id = 'id-Crispy_ContactForm'
self.helper.form_method = 'post'
super(Crispy_ContactForm, self).__init__(*args, **kwargs)
class Meta:
model = Feedback
exclude = ['creation_date']
我的观点:
def bootstrap_test(request):
return render_to_response(
"bootstrap_test.html", {
'feedback_form' : Crispy_ContactForm,
'form' : Crispy_Group_Form,
},
context_instance=RequestContext(request))
我的基本模板:
{% load crispy_forms_tags %}
<form action="{% url feedback %}" method="post" id="id-Crispy_ContactForm" class="form">
{% crispy feedback_form %}
</form>
{% crispy form %}
feedback_form显示两次。好像两种形式都是相同的形式。如果我从模板中删除feedback_form,则会显示“组”表单。如果我重新排列这两个,那么{%crispy form%}位于feedback_from之上,它会正确显示两种不同的形式。
I read the documentation,但无法找到有效的方法。
为什么会发生这种情况,我需要调整哪些才能正确显示?
答案 0 :(得分:2)
好的,我明白了。似乎脆弱的形式会覆盖“形式”变量。这就是为什么它返回相同的两种形式:
<form action="{% url feedback %}" method="post" id="id-Crispy_ContactForm" class="form">
{% crispy feedback_form %}
</form>
{% crispy form %}
但这会返回两种不同的形式:
{% crispy form %}
<form action="{% url feedback %}" method="post" id="id-Crispy_ContactForm" class="form">
{% crispy feedback_form %}
</form>
第一个示例在第二个表单调用可以获取之前覆盖变量“form”。
我只想确认这不是我做错了。因此,我只是颠倒了两个表单被调用的顺序,以便首先出现{%crispy form%}的实例。我不能为表单使用不同的变量,因为我正在使用create / update_object函数。