django_分页

一、基础篇

image.png

=
view模块处理

li = []
for i in range(101):
    li.append(i)
def user_list(request):
    #当page 关键字不存在时 默认1
    current_page = request.GET.get('page',1)
    current_page = int(current_page)
    #页数减-1*10,切片的起始位置
    start = (current_page-1)*10
    # 页数减*10,切片的结束位置
    end = (current_page)*10
    data = li[start:end]
    #显示页数,因为页面没有循环数字的方法,所以后台处理
    page_num,mod_num = divmod(len(li),10)
    #余数不为0页数加一
    if mod_num:
        page_num += 1
    temp_list = []
    for i in range(1,page_num+1):
        if i==current_page:
            temp = '<a class="page active" href="/tp5/?page=%s">%s</a>'%(i,i)
        else:
            temp = '<a class="page" href="/tp5/?page=%s">%s</a>'%(i,i)
        temp_list.append(temp)
    temp_num = ''.join(temp_list)
    return render(request,'user_list.html',{'num':temp_num,'data':data})

html 页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .pageination .page{
            display: inline-block;
            padding: 5px;
            background-color: chocolate;
            margin: 5px;
        }
        .pageination .page.active{
            background-color: greenyellow;
        }
    </style>
</head>
<body>
<ul>
    {% for i in data %}
        <li>  {{ i }}</li>
    {% endfor %}
</ul>
<br>
    <div class="pageination">
        {{ num|safe }}
    </div>
</body>
</html>

二、讲解

对页数限制的讲解

page_count   显示条数
current_page 当前页数
page_num     总页数
11           页码

总页数小于实际展示页数
总页数大于实际展示页数

前提条件总页数11时 

    当前页<=6
        开始页1
        结束页11
    当前页>6
        开始页=当前页-5
        结束页=当前页+6
        当前页+5>总页数
            结束页=总页数+1
            开始页=总页数-10

转换成代码

if page_num<11:
    start_index = 1
    end_index = page_num
else:
    if current_page<=6:  
        start_index = 1
        end_index = 11
    else:
        start_index = current_page -5
        end_index = current_page +6
        if current_page+5>page_num:
            end_index = page_num+1
            start_index = page_num-10

上一页/下一页操作

上一页
当前页等于1时
    上一页功能失效
当前页大于1时
    当前页-1

下一页
当前页等于总页数时
    下一页功能失效
当前页小于总页数时
    当前页+1

代码如下

if current_page ==1:
    prev = '<a class='page' href="javascript:viod(0)">上一页</a>'
else:
    prev = '<a class='page'  href="/tp5/?page=%s">上一页</a>'%(current_page-1)


if current_page ==page_num:
    prev = '<a class='page' href="javascript:viod(0)">下一页</a>'
else:
    prev = '<a class='page'  href="/tp5/?page=%s">下一页</a>'%(current_page+1)

跳转代码如下:

 jump ='''
    <input type='text' /><a onclick='jumpTo(this, "/tp5/?page=");' id='ii'>GO</a>
    <script>
        function jumpTo(ths,base){
            var val = ths.previousSibling.value;
            location.href = base + val;
        }
    </script>
    '''

分页整体代码如下:

def user_list(request):
    page_count = 10
    #当page 关键字不存在时 默认1
    current_page = request.GET.get('page',1)
    current_page = int(current_page)
    #页数减-1*10,切片的起始位置
    start = (current_page-1)*page_count
    # 页数减*10,切片的结束位置
    end = (current_page)*page_count
    data = li[start:end]
    #显示页数,因为页面没有循环数字的方法,所以后台处理
    page_num,mod_num = divmod(len(li),page_count)
    #余数不为0页数加一
    if mod_num:
        page_num += 1
    temp_list = []

    #显示最大页数
    max_page = 11
    if page_num<max_page:
        start_index =1
        end_indx =max_page
    else:
        if current_page<=(max_page+1)/2:
            start_index = 1
            end_indx = max_page
        else:
            start_index = current_page-(max_page-1)/2
            end_indx = current_page+(max_page+1)/2
            if current_page+(max_page-1)/2>page_num:
                start_index = page_num-max_page+1
                end_indx = page_num+1

    if current_page == 1:
        prev = '<a class="page" href="javascript:viod(0)">上一页</a>'
    else:
        prev = '<a class="page"  href="/tp5/?page=%s">上一页</a>' % (current_page - 1)
    temp_list.append(prev)
    # 起始页
    for i in range(int(start_index),int(end_indx)):
        if i==current_page:
            temp = '<a class="page active" href="/tp5/?page=%s">%s</a>'%(i,i)
        else:
            temp = '<a class="page" href="/tp5/?page=%s">%s</a>'%(i,i)
        temp_list.append(temp)
    if current_page == page_num:
        prev = '<a class="page" href="javascript:viod(0)">上一页</a>'
    else:
        prev = '<a class="page"  href="/tp5/?page=%s">上一页</a>' % (current_page + 1)
    temp_list.append(prev)
    jump ='''
    <input type='text' /><a onclick='jumpTo(this, "/tp5/?page=");' id='ii'>GO</a>
    <script>
        function jumpTo(ths,base){
            var val = ths.previousSibling.value;
            location.href = base + val;
        }
    </script>
    '''
    temp_list.append(jump)
    temp_num = ''.join(temp_list)
    return render(request,'user_list.html',{'num':temp_num,'data':data})

三、打包成类

class page():
    '''
    start:获取每页的第一条数据
    end:获取每页的最后一条数据
    all_count: 获取总页数
    page_str: 分页展示,上一页,下一页,跳转
    '''
    def __init__(self,current_page,date_count,page_count=10,max_page = 11):
        '''
        :param current_page: 当前页数,通过request.GET获取
        :param date_count:   数据总个数,用divmod进行取余判断总页数
        :param page_count:   每页显示数据的个数
        :param max_page:     网页可显示的最大总页数
        '''
        self.current_page = current_page
        self.data_count = date_count
        self.page_count = page_count
        self.max_page = max_page

    @property
    def start(self):
        '''
        :return: (当前页-1)*每页展示条数==每页展示数据的第一条
        '''
        return (self.current_page-1)*self.page_count
    @property
    def end(self):
        '''
        :return:  当前页*每页展示条数==每页展示数据的最后一条
        '''
        return self.current_page*self.page_count

    @property
    def all_count(self):
        '''
        :param page_all:   取余的方法,得到商
        :param mod_num:    取余的方法,得到余
        :return:           返回实际总页数
        '''
        v =self.data_count
        page_all, mod_num = divmod(v, self.page_count)
        if mod_num:
            page_all += 1
        return page_all

    def page_str(self):
        temp_list = []
        if self.all_count < self.max_page:
            start_index = 1
            end_indx = self.max_page
        else:
            if self.current_page <= (self.max_page + 1) / 2:
                start_index = 1
                end_indx =self.max_page
            else:
                start_index = self.current_page - (self.max_page - 1) / 2
                end_indx = self.current_page + (self.max_page + 1) / 2
                if self.current_page + (self.max_page - 1) / 2 > self.all_count:
                    start_index = self.all_count - self.max_page + 1
                    end_indx = self.all_count + 1

        if self.current_page == 1:
            prev = '<a class="page" href="javascript:viod(0)">上一页</a>'
        else:
            prev = '<a class="page"  href="/tp5/?page=%s">上一页</a>' % (self.current_page - 1)
        temp_list.append(prev)
        # 起始页
        for i in range(int(start_index), int(end_indx)):
            if i == self.current_page:
                temp = '<a class="page active" href="/tp5/?page=%s">%s</a>' % (i, i)
            else:
                temp = '<a class="page" href="/tp5/?page=%s">%s</a>' % (i, i)
            temp_list.append(temp)
        if self.current_page ==self.all_count:
            prev = '<a class="page" href="javascript:viod(0)">上一页</a>'
        else:
            prev = '<a class="page"  href="/tp5/?page=%s">上一页</a>' % (self.current_page + 1)
        temp_list.append(prev)
        jump = '''
           <input type='text' /><a onclick='jumpTo(this, "/tp5/?page=");' id='ii'>GO</a>
           <script>
               function jumpTo(ths,base){
                   var val = ths.previousSibling.value;
                   location.href = base + val;
               }
           </script>
           '''
        temp_list.append(jump)
        temp_num = ''.join(temp_list)
        return temp_num

使用类

def user_list(request):
    page_count = 10
    #当page 关键字不存在时 默认1
    current_page = request.GET.get('page',1)
    current_page = int(current_page)
    #创建分页对象
    page_obj = page(current_page,len(li))
    #每页数据的起始数据,结束数据
    data = li[page_obj.start:page_obj.end]
    temp_num=page_obj.page_str()
    return render(request,'user_list.html',{'num':temp_num,'data':data})

  • 直接使用版本

__author__ = 'Administrator'
from django.utils.safestring import mark_safe


class Pagination(object):
    def __init__(self, current_page, data_count, per_page_count=1, pager_num=7):
        try:
            self.current_page = int(current_page)
        except Exception as e:
            self.current_page = 1
        self.data_count = data_count
        self.per_page_count = per_page_count
        self.pager_num = pager_num

    @property
    def start(self):
        return (self.current_page - 1) * self.per_page_count

    @property
    def end(self):
        return self.current_page * self.per_page_count

    @property
    def total_count(self):
        v, y = divmod(self.data_count, self.per_page_count)
        if y:
            v += 1
        return v

    def page_str(self, base_url):
        page_list = []

        if self.total_count < self.pager_num:
            start_index = 1
            end_index = self.total_count + 1
        else:
            if self.current_page <= (self.pager_num + 1) / 2:
                start_index = 1
                end_index = self.pager_num + 1
            else:
                start_index = self.current_page - (self.pager_num - 1) / 2
                end_index = self.current_page + (self.pager_num + 1) / 2
                if (self.current_page + (self.pager_num - 1) / 2) > self.total_count:
                    end_index = self.total_count + 1
                    start_index = self.total_count - self.pager_num + 1

        if self.current_page == 1:
            prev = '<li><a class="page" href="javascript:void(0);">上一页</a></li>'
        else:
            prev = '<li><a class="page" href="%s?p=%s">上一页</a></li>' % (base_url, self.current_page - 1,)
        page_list.append(prev)

        for i in range(int(start_index), int(end_index)):
            if i == self.current_page:
                temp = '<li class="active"><a class="page active" href="%s?p=%s">%s</a></li>' % (base_url, i, i)
            else:
                temp = '<li><a class="page" href="%s?p=%s">%s</a></li>' % (base_url, i, i)
            page_list.append(temp)

        if self.current_page == self.total_count:
            nex = '<li><a class="page" href="javascript:void(0);">下一页</a></li>'
        else:
            nex = '<li><a class="page" href="%s?p=%s">下一页</a></li>' % (base_url, self.current_page + 1,)
        page_list.append(nex)

        # jump = """
        # <input type='text'  /><a onclick='jumpTo(this, "%s?p=");'>GO</a>
        # <script>
        #     function jumpTo(ths,base){
        #         var val = ths.previousSibling.value;
        #         location.href = base + val;
        #     }
        # </script>
        # """ % (base_url,)
        #
        # page_list.append(jump)

        page_str = mark_safe("".join(page_list))

        return page_str

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 170,569评论 25 707
  • 方法一:使用pure_pagination进行分页 1. pure_pagination介绍 pure_pagin...
    Jlan阅读 1,081评论 0 7
  • Django中已经实现了很多功能,基本上只要我们需要的功能,都能够找到相应的包。要在Django中实现分页显示,只...
    leyu阅读 530评论 0 2
  • 我们先在 shell 中演示分页器的用法: 分页器示例 现在我们在 view 中使用分页器: 浏览器打开:http...
    SingleDiego阅读 1,562评论 2 3
  • 的发生范德萨的丰盛的是否松岛枫的发生范德萨的丰盛的是否松岛枫的发生范德萨的丰盛的是否松岛枫的发生范德萨的丰盛的是否...
    45454s阅读 142评论 0 1