繁体   English   中英

如何在Wtail中召唤孙子

[英]How to call Grandchild in Wagtail

我正在为Django使用Wagtail,并希望在模板中调用孙子,但不知道如何做到这一点。 我是新手,似乎在wagtail文档中找不到任何东西。 我在这里看到了页面查询参考文档但不知道如何应用它。

我的Django项目树如下:

project/
    home/
        models.py
            > class HomePage
    news/
        models.py
            > class NewsPostPage
            > class NewsIndexPage

在主页模板中,我想将新闻应用中的最新新闻插入到模板中。

家用/ models.py

from django.db import models
from django.utils.translation import ugettext_lazy as _

from modelcluster.models import ParentalKey

from wagtail.admin.edit_handlers import FieldPanel
from wagtail.core.models import Page

from news.models import NewsIndexPage

class HomePage(Page):
    why_choose_us_title_en = models.CharField(
        verbose_name=_('[EN] Why Choose Us Title'),
        max_length=200,
        default='',
        blank=True,
    )

    why_choose_us_subtitle_en = models.CharField(
        verbose_name=_('[EN]Why Choose Us Subtitle'),
        max_length=200,
        default='',
        blank=True,
    )

    content_panels = Page.content_panels + [
        FieldPanel('why_choose_us_title_en', classname='full title'),
        FieldPanel('why_choose_us_subtitle_en'),
    ]

    subpage_types = [
        'news.NewsIndexPage',
    ]

    @property
    def featured_products(self):
        return ProductPage.objects.filter(featured=True)

    news_index = NewsIndexPage

新闻/ models.py

from datetime import timedelta

from django.db import models
from django.utils.translation import ugettext_lazy as _
from django.utils import timezone

from wagtail.admin.edit_handlers import FieldPanel, RichTextFieldPanel
from wagtail.core.fields import RichTextField
from wagtail.core.models import Page
from wagtail.images.edit_handlers import ImageChooserPanel

from base.models import TranslatedField


class NewsPostPage(Page):
    news_title_en = models.CharField(
        max_length=7250,
        verbose_name=_('[EN] News Post Page Title'),
        blank=True,
        default='',
    )
    news_text_en = RichTextField(
        verbose_name=_('[EN] News Text'),
        blank=True,
        default='',
        help_text=_('[EN] News content')
    )
    preview_text_en = RichTextField(
        verbose_name=_('[EN] News Preview Text'),
        blank=True,
        default='',
        help_text=_('[EN] Index Page News Preview Text')
    )
    created = models.DateField(
        verbose_name=_('Release Date'),
        blank=True
    )

    @property
    def recent_posts(self):
        two_months_before = timezone.now().date() - timedelta(days=60)
        posts = NewsPostPage.objects.filter(created__gt=two_months_before)
        return posts

    content_panels = Page.content_panels + [
        FieldPanel('news_title_en', classname='title full'),
        RichTextFieldPanel('news_text_en'),
        RichTextFieldPanel('preview_text_en'),
        FieldPanel('created')
    ]

    parent_page_types = ['NewsIndexPage']


class NewsIndexPage(Page):
    news_index_title_en = models.CharField(
        max_length=250,
        verbose_name=_('[EN] News Index Title'),
        blank=True,
        default='',
    )
    news_index_image = models.ForeignKey(
        'wagtailimages.Image',
        related_name='+',
        null=True,
        on_delete=models.SET_NULL
    )

    content_panels = Page.content_panels + [
        FieldPanel('news_index_title_en'),
        ImageChooserPanel('news_index_image'),
    ]

    subpage_types = ['NewsPostPage']

    @property
    def news_posts(self):
        return self.get_children().live().specific()

    @property
    def recent_posts(self):
        two_months_before = timezone.now().date() - timedelta(days=60)
        posts = NewsPostPage.objects.filter(created__gt=two_months_before)
        return posts

家用/模板

{% block content %}
<div id="kotak-news-events" class="kotak-grid">
     <h4 class="title-strip title-kotak-bawah">Recent News and Events</h4>
     <table>
         {% for post in page.news_index.news_posts.all %}
             <tr>
                 <td>{{ post.created }}</td>
                 <td>{{ post.translated_preview_text|richtext }}</td>
             </tr>
         {% endfor %}
    </table>
</div>

{% endblock %}

我不知道如何在NewsPostPage中插入项目以使其显示在主页模板中。 提前致谢

您要做的是为模板添加其他context Wagtail具有将视图和模型混合在一起的这一很酷的功能。 所以你要做的就是将你的@properties添加到发送到模板的context 像这样的东西:

class NewsIndexPage(Page):

    template = 'templates/news_index_page.html'

    @property
    def news_posts(self):
        return self.get_children().live()

    @property
    def recent_posts(self):
        two_months_before = timezone.now().date() - timedelta(days=60)
        posts = NewsPostPage.objects.filter(created__gt=two_months_before)
        return posts

    def get_context(self, request, *args, **kwargs):
        """Add posts to context"""
        context = super().get_context(request)
        context['recent_posts'] = self.recent_posts
        context['news_posts'] = self.news_posts
        return context

并且因为您将QuerySets返回到模板,所以您可以正常循环它们。 所以你的模板看起来像这样:

{% block content %}
<div id="kotak-news-events" class="kotak-grid">
     <h4 class="title-strip title-kotak-bawah">Recent News and Events</h4>
     <table>
         {% for post in news_posts %} {# Notice the loop here #}
             <tr>
                 <td>{{ post.created }}</td>
                 <td>{{ post.translated_preview_text|richtext }}</td>
             </tr>
         {% endfor %}
    </table>
</div>
{% endblock %}

事实证明,您只需要添加一个属性,我通过添加自定义属性解决,如下所示:

class HomePage(Page):
    why_choose_us_title_en = models.CharField(
        verbose_name=_('[EN] Why Choose Us Title'),
        max_length=200,
        default='',
        blank=True,
    )

    why_choose_us_subtitle_en = models.CharField(
        verbose_name=_('[EN]Why Choose Us Subtitle'),
        max_length=200,
        default='',
        blank=True,
    )

    content_panels = Page.content_panels + [
        FieldPanel('why_choose_us_title_en', classname='full title'),
        FieldPanel('why_choose_us_subtitle_en'),
    ]

    subpage_types = [
        'news.NewsIndexPage',
    ]

    @property
    def featured_products(self):
        return ProductPage.objects.filter(featured=True)

    # removed this line
    # news_index = NewsIndexPage

    # added this code
    @property
    def news_index(self):
        return NewsPostPage.objects.live()

并且仍然将此用于HTML

{% block content %}
<div id="kotak-news-events" class="kotak-grid">
     <h4 class="title-strip title-kotak-bawah">Recent News and Events</h4>
     <table>
         {% for post in page.news_index.all %}
             <tr>
                 <td>{{ post.created }}</td>
                 <td>{{ post.translated_preview_text|richtext }}</td>
             </tr>
         {% endfor %}
    </table>
</div>

{% endblock %}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM