Django1.11自带分页器paginator的使用方法
框架(架构)  /  管理员 发布于 7年前   328
本文实例为大家分享了Django1.11自带分页器Django的具体使用方法,供大家参考,具体内容如下
接下来我编写一个 views ,名classify。
classify,将模拟请求购物网站的分类产品、并分页返回数据。完成如下任务:
1、接受两个参数,type,page。”type”:为请求的购物网站产品类别,如 0代表热门。1代表 家居<
2、分类找到产品。分页返回。
为了方便将要传递的参数直接加载URL中。如:127.0.0.1:8000/classify/0/1/ 请求的是 “type” = 0 ,”page” = 1的数据。
URLS
from django.conf.urls import urlfrom taobao import viewsurlpatterns = [ url(r'^classify/(\d+)/(\d+)/$',views.classify),]
models
“category” :分类,0.代表热门;
class goods(models.Model): category = models.IntegerField('分类',default=0) goods_id = models.CharField('商品ID',max_length=10) goods_name = models.CharField('商品名',max_length=100,default='') goods_price = models.DecimalField('商品价格',max_digits=10,decimal_places=2) goods_Stock = models.IntegerField('商品库存',default=100) sales_Volume = models.IntegerField('销量',default=0) goods_introduce = models.CharField('商品简介',max_length=250,default='') def __str__(self): return self.goods_name
views
from taobao.models import goodsfrom django.core.paginator import Paginator ,PageNotAnInteger ,EmptyPagedef classify(req,type,page):# 接收从url中传递的两个参数。 context = {} context['type'] = int(type) if type == '0': goods_list = goods.objects.order_by('sales_Volume').all() # 按销量排序 else: goods_list = goods.objects.all().filter(category = int(type)).order_by('sales_Volume').all() paginator = Paginator(goods_list,8) # 把商品分成 8 个一页。 try: # 尝试获取请求的页数的 产品信息 goodss = paginator.page(int(page)) #请求页数错误 except PageNotAnInteger: goodss = paginator.page(1) except EmptyPage: goodss = paginator.page(paginator.num_pages) context['goods'] = goodss return render(req,'classify.html',context)
html页面 classify.html
{% block content %} <div style="margin-top: 20px"> <div class="w1240"> <div class="line100"></div> {# 根据type分类 显示不同图片汉字 #} <div class="icon"><img src="https:static/images/type/{{ type }}.png"> <a>{% if type == 0 %}热门{% elif type == 1 %}美味餐厨{% elif type == 2 %}家纺家居{% endif %}</a> </div> </div> </div> <div class="w1240"> <ul class="m-itemList m-itemList-level2Category"> {% for i in goods %} <li class="item"> <div class="m-product"> <span></span> <div class="hd"> <a href="https:taobao/goods/{{ i.goods_id }}" > <img src="https:static/images/goods/{{ i.goods_id}}.jpg" class ="img"> </a> </div> <div class="bd"> <a href="https:taobao/goods/{{ i.goods_id }}" > <h4 class="name">{{ i.goods_name }}</h4> </a> <p style="color: #050505;font-weight: bold;text-align:center" >{{ i.goods_introduce }}</p> <p class="price">¥{{ i.goods_price }}</p> <hr> </div> </div> </li> {% endfor %} </ul> <div style="padding-right:60px"> <span style="float: right"> <a href="https:taobao/classify/{{ type }}/{{ goods.start_index }}" > 第一页 | </a> {% if goods.has_previous %} <a href="https:taobao/classify/{{ type }}/{{ goods.previous_page_number }}" > 上一页 </a> {% if goods.has_next%} <span> | </span> {% endif %} {% endif %} {% if goods.has_next %} <a href="https:taobao/classify/{{ type }}/{{ goods.next_page_number }}" > 下一页 </a> {% endif %} <a href="https:taobao/classify/{{ type }}/{{ goods.end_index }}" >| 末尾页 </a> </span> </div> </div> <div class="clear"></div>{% endblock %}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号