3

ユーザー フィードバック用のフォーム ビューがあります。

urls.py:

url(
    r'^feedback/$',
    'tool.views.Feedback',
    name='feedback'
),
url(
    r'^thanks/$',
    direct_to_template, {
        'template': 'tool_feedback_thanks.html'
    },
    name='feedback_thanks'
),

フォーム.py:

class FeedbackForm(forms.Form):
    yes_no = forms.ChoiceField(
        choices=YES_NO_CHOICE,
        initial=1,
        widget=forms.RadioSelect(attrs={'class': 'can_reveal_input'}),
        label="Are you happy with Our service?"
    )
    comments = forms.CharField(
        widget=forms.Textarea(attrs={
            'class': 'hidden', 'placeholder': 'Leave us your comments...'
        }),
        required=False,
        label=""
    )

ビュー.py:

def Feedback(request,
                 template_name='tool_feedback.html'):
    title = u'Leave us some feedback'
    form = FeedbackForm(request.POST or None)
    if form.is_valid():
        yes_no = form.cleaned_data['yes_no']
        comments = form.cleaned_data['comments']
        sender = "A Unirac website user"
        recipients = ['person@example.com']
        send_mail(yes_no, comments, sender, recipients)
        return HttpResponseRedirect(
            reverse('feedback_thanks')
        )
    return render_to_response(template_name, {
        'title': title,
        'form': form,
    }, RequestContext(request))

これはうまく機能しますが、現在、クライアントはこのフォームをすべてのページに含めるよう求めています。フォームはjsを介して適切なURLに送信できると思いますが、すべてのページにバインドされていないフォームを含める最良の方法は何ですか?

どんな助けでも大歓迎です。

4

3 に答える 3

11

すべてのビューにフォームを含めるために、コンテキスト プロセッサを作成します。

編集:

ユーザーが閲覧していた以前の URL にアクセスするには、URL のみを使用できます。

# yourapp/context_processors.py
def feedback_form_context_processor(request):
    return {
        'feedback_form': FeedbackForm(),
        'feedback_form_url': reverse("feed_app:form_process", args=(request.path))
    }

urls.py は次のようになります。

urlpatterns = patterns('feed_app.views',
    url(r'^process-feedback-form/(?P<next_url>\d+)', 'form_process', name='form_process'),
)

フォームのビュー:

def form_process(request, next_url):
    # Process form, do your stuff here
    # if its valid redirect to the url
    return redirect(next_url)

また、正しいレイアウトになるようにテンプレートを構成する必要があります。たとえば、ベース テンプレートがあるとします。

# templates/base.html
<html>
<body>
..
{% block maincontent %}
{% endblock %}
..
{# The form!!! #}
<form action='{{feedback_form_url}}' method='POST'>
@csrftoken
{{ feedback_form.as_p }}
</form>

</body>
</html>

シンプルなビューを作成するには、正しいテンプレートを使用するだけです。

# templates/just_a_random_view.html

{% extends base.html %}

{% block maincontent %}
<h1>Content!</h1>
{% endblock %}

最後に、設定に含めます。

# settings.py
TEMPLATE_CONTEXT_PROCESSORS = (
    "django.contrib.auth.context_processors.auth",
    ...
    "yourapp.context_processors.feedback_form_context_processor"
)
于 2013-01-15T18:10:20.720 に答える
4

フォームを含める最も簡単な方法は、assignment_tagを使用することだと思います。

テンプレート ライブラリ:

@register.assignment_tag
def feedback_form(format_string):
    return FeedbackForm()

テンプレート内

{% feedback_form as form %}
{# display form... %}
{{ form.as_p }}
于 2013-01-15T17:51:47.220 に答える