Django开发个人博客网站——11、通过regroup实现博客的归档

1、创建归档页面

按照首页建立的方法建立归档页面,将archive.html从模板文件中拷贝到templates目录下,并继承自base.html页面,然后建立视图函数,并通过url将两者联系起来。

archive.html

{% extends 'base.html' %}

{% block title %}
归档
{% endblock %}

{% block title %}
<div class="content-wrap">
...
{% endblock %}

view.py


class ArichiveView(View):

    def get(self, request):
        all_blog = Blog.objects.all().order_by('-create_time')

        # 分页
        try:
            page = request.GET.get('page', 1)
        except PageNotAnInteger:
            page = 1
        p = Paginator(all_blog, 5, request=request)
        all_blog = p.page(page)

        return render(request, 'archive.html', {
            'all_blog': all_blog,
        })

url.py

url(r'^archive/$', ArichiveView.as_view(), name='archive')

同样,我们需要对视图函数进行分页,这里我们分成了5篇/页, 并另外添加了几篇创建时间为2017年的文章。在archive.html页面中创建分页的代码与index.html是完全一致的,然后for循环得到博客的标题与日期即可。

2、通过regroup区分出不同年代

经过上面的操作貌似已经得到需要的结果了,但是我们只能够得到博客标题的列表,并没有按照年代进行归档,比如:我想实现2017年的博客文章全部放在2017年下面,2018年的放在2018年下面,这就需要按照创建时间来对queryset进行分类了。

regroup 官方文档示例

regroup 可以根据一个类列表对象中元素的某个属性对这些元素进行重新分组。例如有这样一个记录各个国家各个城市信息的列表:

cities = [
    {'name': 'Mumbai', 'population': '19,000,000', 'country': 'India'},
    {'name': 'Calcutta', 'population': '15,000,000', 'country': 'India'},
    {'name': 'New York', 'population': '20,000,000', 'country': 'USA'},
    {'name': 'Chicago', 'population': '7,000,000', 'country': 'USA'},
    {'name': 'Tokyo', 'population': '33,000,000', 'country': 'Japan'},
]

我们想按照国家分组显示各个国家的城市信息,效果就像这样:

  • India
    -Mumbai: 19,000,000
    -Calcutta: 15,000,000
  • USA
    -New York: 20,000,000
    -Chicago: 7,000,000
  • Japan
    -Tokyo: 33,000,000

在模板中使用 regroup 模板标签就可以根据 country 属性对 cities 进行分组:

{% regroup cities by country as country_list %}

<ul>
{% for country in country_list %}
    <li>{{ country.grouper }}
    <ul>
        {% for city in country.list %}
          <li>{{ city.name }}: {{ city.population }}</li>
        {% endfor %}
    </ul>
    </li>
{% endfor %}
</ul>

基本用法为 {% regroup 类列表对象 by 列表中元素的某个属性 as 模板变量 %}
例如示例中根据 cities 列表中元素的 country 属性 regroup 了 cities,并通过 as 将分组后的结果保存到了 country_list 模板变量中。
然后可以循环这个分组后的列表。被循环的元素包含两个属性:

  • grouper,就是分组依据的属性值,例如这里的 ‘India’、‘Japan’
  • list,属于该组下原列表中元素

按照上述教程,我们为了实现按照年代归档,可以对all_blog进行如下操作:

{% regroup all_blog.object_list by create_time.year as dates_by_year %}

    {% for year in dates_by_year %}
        {{ year.grouper }}
        {% for blog in year.list %}
            {{ blog.create_time|date:"m-d" }}
            {{ blog.title }}
        {% endfor %}
    {% endfor %}

在这个基础上我们将其添加到之前的样式中,便可得到按照年份进行的归档页面,如我的博客样式:http://www.geerniya.cn/archive/

当然,我们只是按年来划分,还能够继续按照月份来划分,并统计每个月下面发了多少文章,这种排版方式就跟csdn差不多,代码可以参考下面的:

{% regroup all_blog.object_list by create_time.year as dates_by_year %}

    {% for year in dates_by_year %}
        {{ year.grouper }}

        {% regroup year.list by create_time.month as dates_by_month %}
        {% for month in dates_by_month %}
            {{ month.grouper }}
            {% for blog in month.list %}
                {{ blog.title }}
            {% endfor %}
        {% endfor %}
    {% endfor %}

最终得到的效果应该是这样子的:

  • 2018年
    -3月

    • 博客1
    • 博客2

    -1月

    • 博客3
    • 博客4
  • 2017年
    -11月

    • 博客1
    • 博客2

    -9月

    • 博客3
    • 博客4

当然,还可以给它加上数量,这就很简单了,len(month.list)就可以了。

——————————————————————————————————————————

项目的完整代码:django_blog
觉得有用的欢迎给个star。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值