使用两个django脆皮形式

时间:2012-10-19 14:25:26

标签: django-templates django-crispy-forms

我很难同时使用两种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,但无法找到有效的方法。

为什么会发生这种情况,我需要调整哪些才能正确显示?

1 个答案:

答案 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函数。