在Django中显示具有特定标记的页面

时间:2017-07-18 02:43:09

标签: html django wagtail

我使用bootstrap Tab窗格,我需要在每个窗格中显示具有特定标记的帖子,而无需重新加载当然页面 更多细节我正在使用Django与Wagtail CMS我的应用程序基于模型文件

编辑:将标记dict添加到上下文

models.py:

class BlogIndex(Page):
    intro = RichTextField(blank=True)
    def get_context(self, request):
      base_tags = ['foo','boo','voo']
      # Update context to include only published posts, ordered by reverse-chron
        context = super(BlogIndex, self).get_context(request)
        blogpages = self.get_children().live().order_by('-first_published_at')
        context['blogpages'] = blogpages
        context['base_tags'] = base_tags
        return context

class BlogPageTag(TaggedItemBase):
    content_object = ParentalKey('BlogPage', related_name='tagged_items')

class BlogPage(Page):
    #info
    tags = ClusterTaggableManager(through=BlogPageTag, blank=True)
    #contentpanel ....

注意:我正在使用taggit,但似乎我没有很好地处理它

blog_index.html

<div>
  <ul class="nav nav-tabs" role="tablist">
    {% for tag in base_tags %}
    <li role="presentation" ><a href="#{{tag}}" aria-controls="{{tag}}" 
      role="tab" data-toggle="tab">{{tag}}</a></li>
     {% ednfor %}
  </ul>

  <!-- Tab panes -->
  <div class="tab-content">
   {% for tag in base_tags %}
    <div role="tabpanel" class="tab-pane" id="{{tag}}">
    #this is what i'am thinking of 
    #for posts in blogpages :
    # if post tag == "{{tag}}":
    # show post
   </div>
  </div>
  </div>

1 个答案:

答案 0 :(得分:0)

如果你有一些特定的标签,你可以在模板中通过在下面定义它们来调用它们。

另一方面,如果标签会不断增加,那么为标签创建新模型可能会更好。

class PostListView(ListView):
    model = Post

    def get_context_data(self, **kwargs):
        context = super(PostListView, self).get_context_data(**kwargs)
        all_list = Post.objects.all()
        news_list = Post.objects.filter(tag='news')
        context = {
            'all_list': all_list,
            'news_list': news_list,
        }
        return context

修改

你可以这样展示;

{% for object in news_list %}
 {{ object.title }}
 {{ object.timestamp }}
{% endfor %}