Ответ 1
Для CBV:
from django.http import HttpResponseRedirect
return HttpResponseRedirect(self.request.path_info)
Для представления функции:
from django.http import HttpResponseRedirect
return HttpResponseRedirect(request.path_info)
Я делаю приложение Django, которое отслеживает эпизоды телешоу. Это страница для определенного экземпляра Show. Когда пользователь нажимает, чтобы добавить/вычесть сезон, я хочу, чтобы страница перенаправляла их на один и тот же подробный вид, прямо сейчас у меня есть индекс, который показывает список всех экземпляров Show.
показать-detail.html
<form action="{% url 'show:addseason' show=show %}" method="post">
{% csrf_token %}
<button class="btn btn-default" type="submit">+</button>
</form>
<form action="{% url 'show:subtractseason' show=show %}" method="post">
{% csrf_token %}
<button class="btn btn-default" type="submit">-</button>
</form>
views.py
class ShowDetail(DetailView):
model = Show
slug_field = "title"
slug_url_kwarg = "show"
template_name = 'show/show-detail.html'
class AddSeason(UpdateView):
model = Show
slug_field = 'title'
slug_url_kwarg = 'show'
fields = []
def form_valid(self, form):
instance = form.save(commit=False)
instance.season += 1
instance.save()
return redirect('show:index')
class SubtractSeason(UpdateView):
model = Show
slug_field = 'title'
slug_url_kwarg = 'show'
fields = []
def form_valid(self, form):
instance = form.save(commit=False)
if (instance.season >= 0):
instance.season -= 1
else:
instance.season = 0
instance.save()
return redirect('show:index')
urls.py
url(r'^$', views.IndexView.as_view(), name='index'),
url(r'^about/$', views.AboutView.as_view(), name='about'),
# form to add show
url(r'^add/$', views.ShowCreate.as_view(), name='show-add'),
# edit show
#url(r'^(?P<show>[\w ]+)/edit/$', views.ShowUpdate.as_view(), name='show-update'),
# delete show
url(r'^(?P<show>[\w ]+)/delete/$', views.ShowDelete.as_view(), name='show-delete'),
# signup
url(r'^register/$', views.UserFormView.as_view(), name='register'),
# login
url(r'^login/$', views.LoginView.as_view(), name='login'),
# logout
url(r'^logout/$', views.LogoutView.as_view(), name='logout'),
url(r'^error/$', views.ErrorView.as_view(), name='error'),
url(r'^(?P<show>[\w ]+)/$', views.ShowDetail.as_view(), name='show-detail'),
url(r'^(?P<show>[\w ]+)/addseason/$', views.AddSeason.as_view(), name='addseason'),
url(r'^(?P<show>[\w ]+)/subtractseason/$', views.SubtractSeason.as_view(), name='subtractseason'),
url(r'^(?P<show>[\w ]+)/addepisode/$', views.AddEpisode.as_view(), name='addepisode'),
url(r'^(?P<show>[\w ]+)/subtractepisode/$', views.SubtractEpisode.as_view(), name='subtractepisode'),
Я получаю сообщение об ошибке при попытке
return redirect('show:detail')
Это ошибка
NoReverseMatch at /Daredevil/addseason/
Reverse for 'detail' with arguments '()' and keyword arguments '{}' not found. 0 pattern(s) tried: []
Для CBV:
from django.http import HttpResponseRedirect
return HttpResponseRedirect(self.request.path_info)
Для представления функции:
from django.http import HttpResponseRedirect
return HttpResponseRedirect(request.path_info)
перенаправить на ту же страницу (например, http GET) после POST, мне нравится...
return HttpResponseRedirect("") # from django.http import HttpResponseRedirect
он также избегает жесткого кодирования имени маршрута show:detail
и является более четким намерением (для меня, по крайней мере!)
Я предполагаю, что вам нужно предоставить kwarg, чтобы идентифицировать шоу, когда вы перенаправляете, хотя я не вижу код для вашего DetailView
Я бы предположил, что kwarg называется либо pk
или, возможно, show
из соглашения, которое вы использовали в AddSeason
и SubtractSeason
. Попробуйте:
redirect('show:detail', kwargs={'show': instance.pk})
EDIT: имя URL-адреса детали 'show-detail'
, поэтому имя области видимости будет 'show:show-detail'
(если оно находится в пространстве имен show
, как и другие URL-адреса). Я все еще думаю, что для этого понадобится kwarg, попробуйте:
redirect('show:show-detail', kwargs={'show': instance.pk})
Я знаю, что это действительно старая проблема, но я просто столкнулся с тем же вопросом и redirect(request.META.get('HTTP_REFERER', redirect_if_referer_not_found))
исправил мою проблему. Он получает http referer из данных запроса, но если он не предоставлен клиентом, он перенаправит вас на redirect_if_referer_not_found
Это будет работать для просмотра на основе классов и функции 100%:
from django.http import HttpResponseRedirect
...
return HttpResponseRedirect(request.META.get('HTTP_REFERER'))
или же
from django.http import HttpResponseRedirect
...
return HttpResponseRedirect(self.request.META.get('HTTP_REFERER'))
Пример -
class TaskNotificationReadAllView(generic.View):
def get(self, request, *args, **kwargs):
TaskNotification.objects.filter(assigned_to=request.user).update(read=True)
print(request.META.get('HTTP_REFERER'))
return HttpResponseRedirect(request.META.get('HTTP_REFERER'))