django-templates – 使用两个django crispy表单

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

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

最佳答案 好,我知道了.似乎脆弱的形式会覆盖“形式”变量.这就是为什么它返回相同的两种形式:

<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函数.

点赞