В моем представлении я хочу вызвать другое представление и передать ему данные:
return redirect('some-view-name', backend, form.cleaned_data)
, где backend представляет собой объект registration.backends, а form.cleaned_data представляет собой данные данных формы (но оба должны быть отправлены как * args или ** kwargs, чтобы избежать появления ошибки Don't mix *args and **kwargs in call to reverse()!
) Из того, что я нашел в документах:
def my_view(request):
...
return redirect('some-view-name', foo='bar')
Похоже, мне нужно предоставить аргумент "some-view-name", но это просто имя функции представления или имя url? Поэтому я хотел бы сделать его похожим на способ регистрации django, где:
to, args, kwargs = backend.post_registration_redirect(request, new_user)
return redirect(to, *args, **kwargs)
def post_registration_redirect(self, request, user):
return ('registration_complete', (), {})
Хорошо, теперь я могу напрямую вызвать функцию просмотра или мне нужно указать ее URL? И что более важно, как должен выглядеть мой вызов funciotn (и URL-адрес при необходимости)? И backend, и cleaned_data просто передаются через это представление для дальнейшего использования. Я пробовал это, но это неправильно:
url(r'^link/$', some-view-name)
def some-view-name(request, *args):
А также это:
return redirect('some_url', backend=backend, dataform.cleaned_data)
url(r'^link/$', some-view-name)
def some-view-name(request, backend, data):
по-прежнему NoReverseMatch. Но в django-регистрации я видел что-то вроде этого:
url(r'^register/$',register,{'backend': 'registration.backends.default.DefaultBackend'}, name='registration_register'),
def register(request, backend, success_url=None, form_class=None,
disallowed_url='registration_disallowed',
template_name='user/login_logout_register/registration_form.html',
extra_context=None):