Django1.11自帶分頁器paginator的使用方法
本文實(shí)例為大家分享了Django1.11自帶分頁器Django的具體使用方法,供大家參考,具體內(nèi)容如下
接下來我編寫一個 views ,名classify。
classify,將模擬請求購物網(wǎng)站的分類產(chǎn)品、并分頁返回?cái)?shù)據(jù)。完成如下任務(wù):
1、接受兩個參數(shù),type,page。”type”:為請求的購物網(wǎng)站產(chǎn)品類別,如 0代表熱門。1代表 家居<
2、分類找到產(chǎn)品。分頁返回。
為了方便將要傳遞的參數(shù)直接加載URL中。如:127.0.0.1:8000/classify/0/1/ 請求的是 “type” = 0 ,”page” = 1的數(shù)據(jù)。
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中傳遞的兩個參數(shù)。
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:
# 嘗試獲取請求的頁數(shù)的 產(chǎn)品信息
goodss = paginator.page(int(page))
#請求頁數(shù)錯誤
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>
{# 根據(jù)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 %}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺析Python中g(shù)etattr和getattribute的調(diào)用
在Python中,getattr和getattribute是兩個用于屬性訪問的重要函數(shù),它們可以在運(yùn)行時動態(tài)地獲取對象的屬性或自定義屬性訪問行為,下面我們就來學(xué)習(xí)一下它們的具體用法吧2023-11-11
通過Python實(shí)現(xiàn)對SQL Server 數(shù)據(jù)文件大小的監(jiān)控告警功能
這篇文章主要介紹了通過Python實(shí)現(xiàn)對SQL Server 數(shù)據(jù)文件大小的監(jiān)控告警,本文給大家分享問題報(bào)錯信息及解決方案,需要的朋友可以參考下2021-04-04
python如何實(shí)現(xiàn)數(shù)據(jù)的線性擬合
這篇文章主要為大家詳細(xì)介紹了python如何實(shí)現(xiàn)數(shù)據(jù)的線性擬合,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-07-07
yolov5中anchors設(shè)置實(shí)例詳解
在YOLOV5算法之中,針對不同的數(shù)據(jù)集,一般會預(yù)先設(shè)置固定的Anchor,下面這篇文章主要給大家介紹了關(guān)于yolov5中anchors設(shè)置的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
Python使用Selenium、PhantomJS爬取動態(tài)渲染頁面
本文主要介紹了Python使用Selenium、PhantomJS爬取動態(tài)渲染頁面,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05

