1、进入shell模式,进入虚拟环境然后执行下面命令
2、用命令行添加一篇博客
先引入博客模型,
objects.all()显示全部博客信息
实例化一个博客对象,为它初始化各个属性,
其中博客分类需要引入博客分类模型,这里采用切片方式使用第一个博客分类随笔
作者也需要引入django自带的用户模型
save保存进数据库
3、利用for循环添加多个数据
4、命令行模式下进行分页
改一下models.py按日期进行排序
数据库迁移
通过引入分页器类进行分页,每10篇博客1页 ,还可以得到具体某一页
5、分页前后台设计
对应方法
修改对应模板页面:
添加页码,用到page_range注意第一页和最后一页特殊处理,不能跳转,注意if标签使用:
效果
6、分页优化:
对应的方法
EACH_PATH_NUMBER全局变量,在settings.py中设置
对应模板页面修改,这里添加高亮,用active类,注意当前页没有链接,省略号也不能点
<div class="page" align="center">
<ul class="pagination">
<li>
{%if page_of_blogs.has_previous%}
<a href="?page={{ page_of_blogs.previous_page_number }}" aria-label="Previous">
<span aria-hidden="true">«</span>
</a>
{% else %}
<span aria-hidden="true">«</span>
{% endif %}
</li>
{%for page_num in page_range%}
{% if page_num == page_of_blogs.number%}
<li class="active"><span>{{page_num}}</span></li>
{%else%}
{%if page_num == "..."%}
<li ><span>{{page_num}}</span></li>
{%else%}
<li><a href="?page={{page_num}}">{{page_num}}</a></li>
{%endif%}
{%endif%}
{%endfor%}
<li>
{% if page_of_blogs.has_next %}
<a href="?page={{ page_of_blogs.next_page_number }}" aria-label="Next">
<span aria-hidden="true">»</span>
</a>
{% else %}
<span aria-hidden="true">»</span>
{%endif%}
</li>
</ul>
</div>
</div>
分类方法类似
def blogs_with_type(request, blog_type_pk):
blog_type = get_object_or_404(BlogType, pk=blog_type_pk)
blog_all_list= Blog.objects.filter(blog_type=blog_type)
paginator = Paginator(blog_all_list, settings.EACH_PAGE_NUMBER) # 定义一个分页器,每页10篇
page_num = request.GET.get('page', 1) # 返回一个字典,默认值是1
page_of_blogs = paginator.get_page(page_num) # 返回对应页的博客
current_page_num = page_of_blogs.number
print(current_page_num)
page_range = [x for x in range(current_page_num - 2, current_page_num + 3) if
(x > 0 and x < paginator.num_pages + 1)]
if page_range[0] - 1 >= 2:
page_range.insert(0, "...")
if paginator.num_pages - page_range[-1] >= 2:
page_range.append("...")
if page_range[0] != 1:
page_range.insert(0, 1)
if page_range[-1] != paginator.num_pages:
page_range.append(paginator.num_pages)
context = {}
context['blogs'] = page_of_blogs.object_list
context['page_of_blogs'] = page_of_blogs
context['blog_types'] = BlogType.objects.all()
context['page_range'] = page_range
return render_to_response('blog/blogs_with_type.html', context)
效果