2017-10-10 5 views
4

djangoCMS로 웹 사이트를 만들고 apphooks, cms 플러그인, 마법사 등을 많이 사용했습니다. 우리는 홈페이지에 표시되어야하는 핵심 데이터를 보유한 간단한 모델 .djangoCMS render_model을 사용한 사용자 정의 inclusion templatetag

from django.db import models 
from django.utils.text import slugify 
from django.urls import reverse 

from cms.models.fields import PlaceholderField 
from djangocms_text_ckeditor.fields import HTMLField 


class Programme(models.Model): 
    name = models.CharField(max_length=60, unique=True) 
    slug = models.SlugField() 
    icon = models.CharField(max_length=50, unique=True) 
    introduction = HTMLField() 
    overview = PlaceholderField(
     'programme_overview', 
     related_name='programmes_overview' 
    ) 

    def __str__(self): 
     return self.name 

    def get_absolute_url(self): 
     return reverse(
      'programmes:programme-detail', 
      kwargs={'slug': self.slug} 
     ) 

    def save(self, *args, **kwargs): 
     if not self.pk: 
      self.slug = slugify(self.name) 
     super(Programme, self).save(*args, **kwargs) 

models.py

나는이 목적을 위해 사용자 정의의 포함 templatetag을 만들하기로 결정했다. 나는 cms_tags에서 render_model 사용하는 템플릿에서

from django import template 

from ..models import Programme 

register = template.Library() 

@register.inclusion_tag('programmes/programme_list.html') 
def programme_list(): 
    programmes = Programme.objects.all() 
    return {'programmes': programmes} 

templatetags/programmes_tags

, 편집자가 프론트 엔드에서 내용을 편집 할 수 있어야하기 때문이다. 나는 홈페이지를 열 때

{% load programmes_tags %} 
{% programme_list %} 

이 오류가 발생합니다 :

templates/programmes/programme_list.html

{% load cms_tags %} 

{% for programme in programmes %} 
    <div class="col-lg-2 col-md-4 col-sm-6 col-xs-12 text-center flex-item"> 
     <div class="service-box"> 
      <i class="fa fa-4x {{ programme.icon }} text-primary" style="visibility:visible;"></i> 
      <h3> 
       <a href="{% url 'programmes:programme-detail' programme.slug %}"> 
        {{ programme.name }} 
       </a> 
      </h3> 
      <p class="text-muted"> 
       {% render_model programme 'introduction' %} 
      </p> 
     </div> 
    </div> 
{% endfor %} 

태그는 현재 홈페이지에 대한 템플릿에 사용됩니다

다음 템플릿입니다
KeyError: 'request' 

분명히 render_model 태그가 request에 액세스해야합니다. 나는이 같은 templatetag 변경하려고하면 :

@register.inclusion_tag('programmes/programme_list.html', takes_context=True) 
def programme_list(context): 
    programmes = Programme.objects.all() 
    context.update({'programmes': programmes}) 
    return context 

requestRequestContext의 일부로 전달되지만,이 오류가 발생합니다 :

ValueError: dictionary update sequence element #1 has length 1; 2 is required 

를 내가 제대로 업데이트해야합니다 어떻게 RequestContext?
templatetag를 사용하는 것이 올바른 방법이 아니라면 더 나은 해결책이 무엇인지 지적하십시오.

답변

0

take_context를 거기에두고 이전 코드를 사용하십시오. 이것을 테스트하지 않았습니다.

@register.inclusion_tag('programmes/programme_list.html', takes_context=True) 
def programme_list(context): 
    request = context['request'] 
    programmes = Programme.objects.all() 
    return {'programmes': programmes, 'request': request} 
+0

감사합니다. 나는 그것을 시도했지만 도움이되지 않습니다. 'django.template.exceptions.TemplateSyntaxError : 'sekizai.context_processors.sekizai'템플릿 컨텍스트 프로세서를 활성화하거나 'sekizai.context.SekizaiContext'를 사용하여 템플릿을 렌더링해야합니다. ' – cezar

+0

그리고' sekizai.context_processors.sekizai'는 TEMPLATES [0] [ 'OPTIONS'] [ 'context_processors']'의 설정에 있습니다. – cezar