1. 程式人生 > 程式設計 >Django1.11自帶分頁器paginator的使用方法

Django1.11自帶分頁器paginator的使用方法

本文例項為大家分享了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 url
from taobao import views

urlpatterns = [
 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 goods

from django.core.paginator import Paginator,PageNotAnInteger,EmptyPage

def 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="/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="/taobao/goods/{{ i.goods_id }}" >
    <img src="/static/images/goods/{{ i.goods_id}}.jpg" class ="img">
   </a>
   </div>

   <div class="bd">
    <a href="/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="/taobao/classify/{{ type }}/{{ goods.start_index }}" > 第一頁 | </a>
  {% if goods.has_previous %}
  <a href="/taobao/classify/{{ type }}/{{ goods.previous_page_number }}" > 上一頁 </a>
  {% if goods.has_next%}
  <span> | </span>
  {% endif %}
  {% endif %}
  {% if goods.has_next %}
  <a href="/taobao/classify/{{ type }}/{{ goods.next_page_number }}" > 下一頁 </a>
  {% endif %}
  <a href="/taobao/classify/{{ type }}/{{ goods.end_index }}" >| 末尾頁 </a>
 </span>
 </div>
 </div>
 <div class="clear"></div>

{% endblock %}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。