好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > Django實現翻頁的示例代碼

Django實現翻頁的示例代碼

熱門標簽:手機網頁嵌入地圖標注位置 天津電話機器人公司 開封語音外呼系統代理商 400電話辦理哪種 電銷機器人的風險 地圖標注線上如何操作 開封自動外呼系統怎么收費 河北防封卡電銷卡 應電話機器人打電話違法嗎

Django提供了翻頁器。用Django的Paginator類實現

一、views模塊導入Paginator類實現數據分頁

ApiTest/apiviews.py

每行都加了注釋,希望有助于理解。

from django.shortcuts import render
from ApiTest.models import ApiTest
from django.contrib.auth.decorators import login_required
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger, InvalidPage


@login_required
def api_test_manage(request):
    username = request.session.get('user', '')
    # 獲取所有接口測試數據
    apitest_list = ApiTest.objects.all().order_by('id')
    # 生成Paginator對象對數據分頁,每頁顯示10條數據
    paginator = Paginator(apitest_list,10)
    # 使用request.GET.get()函數獲取url中的page參數的數值。默認第1頁
    page = request.GET.get('page', 1)
    # 把獲取的當前頁碼數轉換成整數類型
    current_page = int(page)
    try:
     # 獲取查詢頁數的接口數據列表,page()函數會判斷page實參是否是有效數字。page()函數源碼附在文章的最后
        apitest_list = paginator.page(page)
    except PageNotAnInteger:
        apitest_list = paginator.page(1)
    except (EmptyPage, InvalidPage):
     # paginator.num_pages
        apitest_list = paginator.page(paginator.num_pages)
    return render(request, "apitest_manage.html", {'user': username, 'apitests': apitest_list})

二、將views的數據渲染到前端模板上

在對應的html文件中加入此段代碼即可。

div class="container">
    ul class="pagination" id="pager">
        {# 上一頁鏈接 #}
        {% if apitests.has_previous %}
        li class="previous">a href="/apitest_manage/?page={{ apitests.previous_page_number }}" rel="external nofollow" >上一頁/a>/li>
        {% else %}
        li class="previous disabled">a href="#" rel="external nofollow"  rel="external nofollow" >上一頁/a>/li>
        {% endif %}

        {# 中間數字顯示 #}
        {%  for num in apitests.paginator.page_range %}
            {%  if num == currentPage %}
                li class="item active">a href="/apitest_manage/?page={{ num }}" rel="external nofollow"  rel="external nofollow" >{{ num }}/a>/li>
            {% else %}
                li class="item">a href="/apitest_manage/?page={{ num }}" rel="external nofollow"  rel="external nofollow" >{{ num }}/a>/li>
            {% endif %}
        {% endfor %}

        {# 下一頁鏈接 #}
        {% if apitests.has_next %}   {# 如果有下一頁,則正常顯示下一頁鏈接 #}
            li class="next">a href="/apitest_manage/?page={{ apitests.next_page_number }}" rel="external nofollow" >下一頁/a>/li>
        {% else %}
            li class="next disabled">a href="#" rel="external nofollow"  rel="external nofollow" >下一頁/a>/li>
        {% endif %}

    /ul>
/div>

三、效果展示

四、Paginator類源碼

此類主要用在views文件

class Paginator:
    def __init__(self, object_list, per_page, orphans=0,
                 allow_empty_first_page=True):
        self.object_list = object_list
        self._check_object_list_is_ordered()
        self.per_page = int(per_page)
        self.orphans = int(orphans)
        self.allow_empty_first_page = allow_empty_first_page

    def validate_number(self, number):
        """Validate the given 1-based page number."""
        try:
            if isinstance(number, float) and not number.is_integer():
                raise ValueError
            number = int(number)
        except (TypeError, ValueError):
            raise PageNotAnInteger(_('That page number is not an integer'))
        if number  1:
            raise EmptyPage(_('That page number is less than 1'))
        if number > self.num_pages:
            if number == 1 and self.allow_empty_first_page:
                pass
            else:
                raise EmptyPage(_('That page contains no results'))
        return number

    def get_page(self, number):
        """
        Return a valid page, even if the page argument isn't a number or isn't
        in range.
        """
        try:
            number = self.validate_number(number)
        except PageNotAnInteger:
            number = 1
        except EmptyPage:
            number = self.num_pages
        return self.page(number)

    def page(self, number):
        """Return a Page object for the given 1-based page number."""
        number = self.validate_number(number)
        bottom = (number - 1) * self.per_page
        top = bottom + self.per_page
        if top + self.orphans >= self.count:
            top = self.count
        return self._get_page(self.object_list[bottom:top], number, self)

    def _get_page(self, *args, **kwargs):
        """
        Return an instance of a single page.

        This hook can be used by subclasses to use an alternative to the
        standard :cls:`Page` object.
        """
        return Page(*args, **kwargs)

    @cached_property
    def count(self):
        """Return the total number of objects, across all pages."""
        c = getattr(self.object_list, 'count', None)
        if callable(c) and not inspect.isbuiltin(c) and method_has_no_args(c):
            return c()
        return len(self.object_list)

    @cached_property
    def num_pages(self):
        """Return the total number of pages."""
        if self.count == 0 and not self.allow_empty_first_page:
            return 0
        hits = max(1, self.count - self.orphans)
        return ceil(hits / self.per_page)

    @property
    def page_range(self):
        """
        Return a 1-based range of pages for iterating through within
        a template for loop.
        """
        return range(1, self.num_pages + 1)

    def _check_object_list_is_ordered(self):
        """
        Warn if self.object_list is unordered (typically a QuerySet).
        """
        ordered = getattr(self.object_list, 'ordered', None)
        if ordered is not None and not ordered:
            obj_list_repr = (
                '{} {}'.format(self.object_list.model, self.object_list.__class__.__name__)
                if hasattr(self.object_list, 'model')
                else '{!r}'.format(self.object_list)
            )
            warnings.warn(
                'Pagination may yield inconsistent results with an unordered '
                'object_list: {}.'.format(obj_list_repr),
                UnorderedObjectListWarning,
                stacklevel=3
            )

五、Page類源碼

此類主要用在html文件

class Page(collections.abc.Sequence):

    def __init__(self, object_list, number, paginator):
        self.object_list = object_list
        self.number = number
        self.paginator = paginator

    def __repr__(self):
        return 'Page %s of %s>' % (self.number, self.paginator.num_pages)

    def __len__(self):
        return len(self.object_list)

    def __getitem__(self, index):
        if not isinstance(index, (int, slice)):
            raise TypeError(
                'Page indices must be integers or slices, not %s.'
                % type(index).__name__
            )
        # The object_list is converted to a list so that if it was a QuerySet
        # it won't be a database hit per __getitem__.
        if not isinstance(self.object_list, list):
            self.object_list = list(self.object_list)
        return self.object_list[index]

    def has_next(self):
        return self.number  self.paginator.num_pages

    def has_previous(self):
        return self.number > 1

    def has_other_pages(self):
        return self.has_previous() or self.has_next()

    def next_page_number(self):
        return self.paginator.validate_number(self.number + 1)

    def previous_page_number(self):
        return self.paginator.validate_number(self.number - 1)

    def start_index(self):
        """
        Return the 1-based index of the first object on this page,
        relative to total objects in the paginator.
        """
        # Special case, return zero if no items.
        if self.paginator.count == 0:
            return 0
        return (self.paginator.per_page * (self.number - 1)) + 1

    def end_index(self):
        """
        Return the 1-based index of the last object on this page,
        relative to total objects found (hits).
        """
        # Special case for the last page because there can be orphans.
        if self.number == self.paginator.num_pages:
            return self.paginator.count
        return self.number * self.paginator.per_page

到此這篇關于Django實現翻頁的示例代碼的文章就介紹到這了,更多相關Django 翻頁內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • Django使用paginator插件實現翻頁功能的實例

標簽:江蘇 常州 六盤水 宿遷 駐馬店 成都 蘭州 山東

巨人網絡通訊聲明:本文標題《Django實現翻頁的示例代碼》,本文關鍵詞  Django,實現,翻頁,的,示例,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Django實現翻頁的示例代碼》相關的同類信息!
  • 本頁收集關于Django實現翻頁的示例代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: xxxx.欧美| 天天操天天干天天爱| 色成人综合网| 免费无码无码国产AV在线观看| 免费美女黄色| 爽?躁多水?快?深点黑人| 国产一级毛片普通话对自| 黑人a级片| 91?无码?国产?| 善良的岳HD中字伦理| 《熟妇的荡欲》无删| 蜜桃精品一区二区在线观看| 欧美最婬乱婬爆婬A片| 国产成人免费影片在线观看| 全文都是肉高h按摩技师| 色戒hd版无删减| ?| 桃花岛成年入口进入thd688| 日日摸夜夜爽啪啪av资源站| 亚洲AV永久无码精品无码最全| 野花日本HD免费高清版9| 禁断介护老人中文字幕| 娇妻帮邻居许老勃起| 18??????????网站| 女人下边紧了好还是松点好| 亚洲欧美另类国产综合| 亚洲成在人| 91无码人妻精品一区二区三区四| 摸腿呻吟娇喘爆乳吃胸视频| 人妻斩り56歳佳子AV| 啊轻点灬太粗嗯太深了快三| Av电影在线观看| 国产一卡二卡3卡4卡四卡在线| 婷婷综合橙色AV精品综合视频| 国产交换娇妻在线观看中字| 欧美日韩视频在线一区二区| china中国东北打桩机| 调教她羞辱调教训练h| 国产精品亚洲专区一区| 大山里的性混乱小说| 狠狠狠狠狠操|