前端分页
将所有数据一次性返回给前端页面,再通过js进行分页,对数据库负担比较大。
后端分页
在数据库查询的时候,就查询出指定页的数据,不多查。
Article.object.all()[:5]
Queryset有惰性特质,在不涉及到:
1、截取
2、排序
3、循环
的情况下,不会遍历执行
django有一个插件paginator专门负责分页
def newlist(request,p=1):
p=int(p)
articles=App1.objects.order_by("-id")
paginator=Paginator(articles,9)#articles表示所有数据,9表示一页有九条数据
page=paginator.page(p)#p代表第几页#获取具体页的数据
start=p-3
end=p+2
if start<=0:
end-=start
start=0
page_range=paginator.page_range[start:end]#显示页码
return render_to_response('newslistpic.html',locals())
路由设置
re_path('newlist/(?P<p>\d+)', newlist),
path('newlist/', newlist),