Мой код в myapp_extras.py:
from django import template
register = template.Library()
@register.inclusion_tag('new/userinfo.html')
def address():
address = request.session['address']
return {'address':address}
в 'settings.py':
TEMPLATE_CONTEXT_PROCESSORS =(
"django.core.context_processors.auth",
"django.core.context_processors.debug",
"django.core.context_processors.i18n",
"django.core.context_processors.media",
'django.core.context_processors.request'
)
но я получил ошибку:
TemplateSyntaxError at /items/
Caught an exception while rendering: global name 'request' is not defined
Original Traceback (most recent call last):
File "C:\Python25\lib\site-packages\django\template\debug.py", line 71, in render_node
result = node.render(context)
File "C:\Python25\lib\site-packages\django\template\__init__.py", line 915, in render
dict = func(*args)
File "C:\p4\projects\myproject\..\myproject\invoice\templatetags\myapp_extras.py", line 9, in address
address = request.session['address']
NameError: global name 'request' is not defined
Я сослался на этого В Django, действительно ли возможно получить доступ к текущему сеансу пользователя из пользовательского тега?.
запрос
не является переменной в этой области. Вы должны сначала получить его в контексте. Pass Take_Context
в декоратор и добавьте контекст
к аргументам тега .
Мне нравится:
@register.inclusion_tag('new/userinfo.html', takes_context=True)
def address(context):
request = context['request']
address = request.session['address']
return {'address':address}
Я пробовал решение, описанное выше (от Ignacio Vazquez-Abrams), и оно фактически не работало, пока я не обнаружил, что контекстные процессоры работают только с RequestContext
классом-оберткой.
Поэтому в метод main view нужно добавить следующую строку:
from django.template import RequestContext
return render_to_response('index.html', {'form': form, },
context_instance = RequestContext(request))