簡體   English   中英

使用djangoCMS render_model的自定義包含模板標簽

[英]Custom inclusion templatetag with djangoCMS render_model

我用djangoCMS創建了一個網站,並大量使用apphooks,cms插件,向導等。我們有一個簡單的應用程序,只有一個模型保存應顯示在主頁上的核心數據。

models.py

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)

我決定為此目的創建一個自定義包含模板標簽。

templatetags/programmes_tags

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}

在模板中,我使用render_model中的cms_tags ,因為編輯器應該能夠編輯前端中的內容。 這是模板:

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 %}

該標記現在用於主頁的模板中:

{% load programmes_tags %}
{% programme_list %}

當我打開主頁時,它會拋出一個錯誤:

KeyError: 'request'

顯然, render_model標記需要訪問request 當我嘗試更改模板標簽時:

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

request作為RequestContext的一部分傳遞,但隨后拋出此錯誤:

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

我該如何正確更新RequestContext
如果使用templatetag不是正確的方法,請指出什么是更好的解決方案。

讓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}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM