我在footer.html中有一个订阅表单,它包含在base.html中,因此该表单应该适用于站点上的每个页面。为此,我使用了context\u处理器解决方案,一切正常,但由于某些原因,数据没有保存在DB中。我花了几个小时在堆栈上寻找合适的解决方案,但没能节省下来
类似的问题是here,但也不适合我。应该是一些简单的事情,但由于我对django的新认识,这件事变得有点复杂。 请帮忙。提前谢谢
注意:请确定,“catalog.context\u processors.SubscribeFormGlobal”已添加到设置
模型.py
from django.db import models
class Subscriber(models.Model):
email = models.EmailField()
def __str__(self):
return self.email
forms.py
from django import forms
from .models import Subscriber
class SubscriberForm(forms.ModelForm):
class Meta:
model = Subscriber
fields = ('email',)
上下文处理器.py
from .forms import SubscriberForm
def SubscribeFormGlobal(request):
return {'subscribe_form': SubscriberForm()}
视图.py
def subscribe_us(request):
if request.method == "POST":
subscribe_form = SubscriberForm(request.POST)
if subscribe_form.is_valid():
subscribe_form.save(commit=False)
subscribe_form.author = request.user
subscribe_form.published_date = timezone.now()
subscribe_form.save()
else:
subscribe_form = SubscriberForm()
return render(request, '', {'subscribe_form': subscribe_form})
url.py
from catalogue import views
from catalogue.models import Bancnote
urlpatterns = [
url(r'^$', views.bons_list, name='bons_list'),
url(r'^(?P<pk>\d+)$', DetailView.as_view(model=Bancnote, template_name='catalogue/bon_detail.html')),
url(r'^feedback/$', views.feedback, name='feedback'),
url(r'^$', views.subscribe_us, name='subscribe')
]
footer.html
{% load widget_tweaks %}
{% block footer %}
<footer>
<div class="container-fluid">
<div class="container-fluid">
<div class="row" style="padding-top: 15px;">
<div class="col-lg-1">
<i style="color:#f84c48; margin-top: -10px" class="fa fa-envelope-o fa-5x"
aria-hidden="true"></i>
</div>
<div class="col-lg-4 col-lg-offset-1">
<p id="text-email">Test</p>
</div>
<div class="col-lg-6">
<form action="{% url 'subscribe' %}" method="POST">
{% csrf_token %}
<div class="input-group input-group-lg">
{{ subscribe_form.as_p }}
<span class="input-group-btn">
<button type="submit" style="background:#1d6e87; color: white; border: 0"
class="btn btn-default">Subscriber</button>
</span>
</div>
</form>
</div>
</div>
</div>
<hr style="margin: 10px 0; border-color: #d6d6d6">
</div>
<div class="container-fluid">
<div class="row">
<div class="col-lg-4 col-md-4">
<h4>Contacts</h4>
<p>
<i class="fa fa-map-marker contacts"></i>
Test
</p>
<p>
<i class="fa fa-phone contacts"></i>
Test
</p>
<p>
<i class="fa fa-envelope contacts"></i>
WCUB@gmail.com
</p>
</div>
<div class="col-lg-4 col-md-4">
Lorem ipsum dolor sit amet, consectetur adipisicing elit. Consectetur error quidem sit velit? A,
ab, animi aut culpa ea eos ex illo itaque iure nisi officiis quasi quia soluta veritatis!
</div>
<div class="col-lg-4 col-md-4">
<div id="social-networks">
<h4>Social Networks</h4>
<a href="https://vk.com/" target="_blank"><i class="fa fa-vk"></i></a>
<a href="https://facebook.com/" target="_blank"><i class="fa fa-facebook"></i></a>
<a href="https://twitter.com/" target="_blank"><i class="fa fa-twitter"></i></a>
<a href="https://instagram.com/" target="_blank"><i class="fa fa-instagram"></i></a>
</div>
</div>
</div>
</div>
</div>
</footer>
{% endblock %}
你的问题在于你的url.py
django匹配url的方式将匹配与请求匹配的第一个regex。url.py的编写方式从不调用subscribe视图。您将需要一个不同的url来将请求发布到以使其工作
您不能有两个具有相同URL模式的视图-您在根URL上同时拥有bons\u list和subscribe。这意味着只调用bons\u列表视图
你需要给订阅自己的网址
(执行此操作时,提交时会出现错误,因为
render
调用中的模板名称为空;不确定为什么要这样做,需要提供一个模板,以便在表单无效时呈现。当有效时,也应该重定向;大概您会重定向回主页。)相关问题 更多 >
编程相关推荐