我已将此事研究死亡,但还没有找到我需要完成表单最后一部分所需的内容。
我的页脚中有一个简单的2字段表单用于简报注册。我正在使用inclusion_tag
,因为我需要在每个页面上包含该表单。
表格有效;有几个故障,为了论证,它工作,我点击提交,电子邮件发送给我。问题是我在ajax网址的控制台中获得500(internal server error)
。我假设它不是真的应该重定向到url,而只是处理表单。以下是我的代码;我希望有人可以轻松指出我的问题。感谢。
包含标记
@register.inclusion_tag('includes/cta_form.html', takes_context=True)
def footer_newsletter_signup(context):
title = 'Newsletter Signup'
form = CTASignupForm()
context = {
'form': form,
'title': title,
}
return context
的Ajax
$('#sendSignupForm').click(function (e) {
e.preventDefault();
var mForm = $('#signupForm').serialize();
console.log(mForm);
$.ajax({
type: 'POST',
url: '{% url 'pages:cta_signup' %}',
data: mForm,
success: function (data) {
$("input").val('')
},
error: function (data) {
$("input").addClass('error')
}
})
})
cta_form.html
<form action="{% url 'pages:cta_signup' %}" method="POST" id="signupForm">
{% csrf_token %}
{{ form.name }}
{{ form.email }}
<button class="btn btn-black no-margin-bottom btn-small" type="submit" id="sendSignupForm">Submit</button>
</form>
查看
def cta_signup(request):
if request.method == "POST":
form = CTASignupForm(request.POST)
if form.is_valid():
name = form.cleaned_data['name']
email = form.cleaned_data['email']
subject = 'This is a response from Soledad Footer Signup Form'
from_email = settings.DEFAULT_FROM_EMAIL
recipient_list = [from_email, 'charles@netfinity.net']
ctx = {
'subject': subject,
'name': name,
'email': email
}
message = get_template('email_forms/cta_signup_email.html').render(Context(ctx))
msg = EmailMessage(subject, message, from_email=from_email, to=recipient_list)
msg.content_subtype = 'html'
msg.send()
messages.success(request, "Thank you, we received your message")
if form.errors:
json_data = json.dumps(form.errors)
return HttpResponseBadRequest(json_data, content_type='application/json')
else:
raise Http404
控制台错误的屏幕截图
答案 0 :(得分:2)
视图必须始终返回响应。如果表格有效,则不予以;那是服务器错误。
在is_valid块的末尾返回HttpResponse()
。