Django开发个人博客项目-(8)博客归档
2019-07-24 09:06
495 查看
版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/u013054796/article/details/97100579
欢迎访问我的博客:小羊驼的部落阁
1、创建归档页面
按照首页建立的方法建立归档页面,将archive.html从模板文件中拷贝到templates目录下,并继承自base.html页面,然后建立视图函数,并通过url将两者联系起来。
archive.html
{% extends 'base.html' %} {% block title %} 归档 {% endblock %} {% block content %} <div class="content-wrap"> ... {% endblock %}
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(r'^archive/$', ArichiveView.as_view(), name='archive')
同样,我们需要对视图函数进行分页,这里我们分成了5篇/页, 并另外添加了几篇创建时间为2019年的文章。在archive.html页面中创建分页的代码与index.html是完全一致的,然后for循环得到博客的标题与日期即可。
2、通过regroup区分出不同年代
经过上面的操作貌似已经得到需要的结果了,但是我们只能够得到博客标题的列表,并没有按照年代进行归档,比如:我想实现2017年的博客文章全部放在2017年下面,2018年的放在2018年下面,这就需要按照创建时间来对queryset进行分类了。
{% 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 %}
在这个基础上我们将其添加到之前的样式中,便可得到按照年份进行的归档页面
相关文章推荐
- Django开发个人博客项目-(9)实现标签云样式和标签下所有文章展示
- Django开发个人博客项目-(10)通过markdown完成博客的展示和完成博客详情页面
- Django开发个人博客项目-(11)博客分类与最后功能完善
- Django开发个人博客网站——3、使用pycharm创建博客项目
- Django开发个人博客网站——11、通过regroup实现博客的归档
- Django开发个人博客网站——17、博客添加RSS订阅
- Django开发个人博客网站——22、博客的最后完善
- Django项目开发实例之我的博客
- Django开发了个人博客以及开通公众号
- Django开发个人博客网站——9、模板的继承
- django开发个人简易Blog——构建项目结构
- Django开发个人博客网站——21、实现博客的统计功能
- django--个人博客项目
- Django个人博客开发(七:CommentStore CommentShow.、八:blogDetailShow captcha.js、九:search css)
- django搭建个人博客11,项目发布展示
- Django开发个人博客网站——18、实现博客的分类
- Django开发个人博客网站——31、给网站添加上404、500页面
- Django个人博客开发(十:lblog/models.py lblog/index.html、十一:lsite index.html)
- Django搭建个人博客一1、Django博客开发环境
- Django个人博客开发(十二:ueditor paginator、十三:log user)