91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Django html 分頁

發布時間:2020-08-10 23:43:14 來源:網絡 閱讀:921 作者:lvnian2009 欄目:開發技術


16.分頁

django 自帶的分頁:django paginator

參考:https://docs.djangoproject.com/en/1.10/topics/pagination/

>>> from django.core.paginator import Paginator
>>> objects = ['john', 'paul', 'george', 'ringo']
>>> p = Paginator(objects, 2)

>>> p.count
4
>>> p.num_pages     ##一共多少頁,也可說是最后一頁的頁數
2
>>> p.page_range
[1, 2]
>>>

>>> page1 = p.page(1)
>>> page1
<Page 1 of 2>
>>> page1.object_list
['john', 'paul']

>>> page2 = p.page(2)
>>> page2.object_list
['george', 'ringo']
>>> page2.has_next()
False
>>> page2.has_previous()
True
>>> page2.has_other_pages()
True
>>> page2.next_page_number()
Traceback (most recent call last):
...
EmptyPage: That page contains no results
>>> page2.previous_page_number()
1
>>> page2.start_index() # The 1-based index of the first item on this page
3
>>> page2.end_index() # The 1-based index of the last item on this page
4
>>> p.page(0)
Traceback (most recent call last):
...
EmptyPage: That page number is less than 1
>>> p.page(3)
Traceback (most recent call last):
...
EmptyPage: That page contains no results

###################################
###################################
###################################  后端處理
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger
from django.shortcuts import render

def listing(request):
    contact_list = Contacts.objects.all()     ###把內容取出來,但不是真正取出去。
    paginator = Paginator(contact_list, 25) # Show 25 contacts per page

    page = request.GET.get('page')         ##前臺說要去那一頁,就提交到這
    try:
        contacts = paginator.page(page)
    except PageNotAnInteger:
        # If page is not an integer, deliver first page.     ##如果頁面不是一個整數,交付第一頁
        contacts = paginator.page(1)
    except EmptyPage:
        # If page is out of range (e.g. 9999), deliver last page of results.
        contacts = paginator.page(paginator.num_pages)         ##如果取的頁數超過最大頁數,就返回最后一頁

    return render(request, 'list.html', {'contacts': contacts})    ##把獲取到的頁面返回到前臺



###################################
###################################
###################################  前端處理

{% for contact in contacts %}
    {# Each "contact" is a Contact model object. #}
    {{ contact.full_name|upper }}<br />
    ...
{% endfor %}

<div class="pagination">
    <span class="step-links">
        {% if contacts.has_previous %}      ##判斷后端傳來的頁數,有沒有上一頁
            <a href="?page={{ contacts.previous_page_number }}">previous</a>
        {% endif %}

        <span class="current">
            Page {{ contacts.number }} of {{ contacts.paginator.num_pages }}.
        </span>

        {% if contacts.has_next %}  ##判斷后端傳來的頁數,有沒有下一頁
            <a href="?page={{ contacts.next_page_number }}">next</a>
        {% endif %}    ### ?page ,加上'?'問號。 就是一個get方法。
    </span>
</div>


###################################
###################################
###################################  前端處理,用bootstrap 實現, 作業:線上分頁中的前后幾頁,而不是下面的全部頁面都顯示

                    <nav>
                      <ul class="pagination">
                      {% if articles.has_previous %}
                        <li>
                            <a href="?page={{ articles.previous_page_number }}" aria-label="Previous">
                                <span aria-hidden="true">
                                    &laquo;
                                </span>
                            </a>
                        </li>
                      {% else %}
                        <li>
                            <a href="#" aria-label="Previous">
                                <span aria-hidden="true">
                                    &laquo;
                                </span>
                            </a>
                        </li>

                      {% endif %}

                      {% for p_num in articles.paginator.page_range %}
                        {% if articles.number == p_num %}
                        <li class="active">
                            <a href="#">
                                {{ articles.number }}
                                <span class="sr-only">{{ articles.number }}
                                </span>
                            </a>
                        </li>
                        {% else %}
                        <li >
                            <a href="?page={{ p_num }}">
                                {{ p_num }}
                            </a>
                        </li>
                        {% endif %}
                       {% endfor %}
                        {% if articles.has_next %}
                        <li>
                            <a href="?page={{ articles.next_page_number }}" aria-label="Next">
                                <span aria-hidden="true">
                                    &raquo;
                                </span>
                            </a>
                        </li>
                        {% else %}
                        <li>
                            <a href="#" aria-label="Next">
                                <span aria-hidden="true">
                                    &raquo;
                                </span>
                            </a>
                        </li>
                      {% endif %}
                      </ul>
                    </nav>



下面這個實例,分頁頁面按鈕數最多顯示為3個!

實例:
后端:
def index(request):   ##分頁
    articles_list = models.Article.objects.all().order_by('-publish_date')  ###把內容取出來,但不是真正取出去。
    paginator = Paginator(articles_list, 2) # Show 2 contacts per page

    page = request.GET.get('page')     ##前臺說要去那一頁,就提交到這
    try:
        articles = paginator.page(page)
    except PageNotAnInteger:
        # If page is not an integer, deliver first page.  ##如果頁面不是一個整數,交付第一頁
        articles = paginator.page(1)
    except EmptyPage:
        # If page is out of range (e.g. 9999), deliver last page of results.
        articles = paginator.page(paginator.num_pages) ##如果取的頁數超過最大頁數,就返回最后一頁

    page_range = range(articles.number - 1 ,articles.number + 2)
    max_page = paginator.num_pages
    return render(request,'index.html',{
        'articles': articles,
        'page_range': page_range,
        'max_page': max_page,
    })

前端:
<div class="pagination">
<ul class="pagination">
    {% if articles.has_previous %}
        <li><a href="?page={{ articles.previous_page_number }}">previous</a>
        </li>
    {% endif %}

    {% for p_num in page_range %}
        {% if 0 < p_num and p_num < max_page %}
            {% if articles.number == p_num %}
                <li class="active">
                <a href="#">
                {{ articles.number }}
                <span class="sr-only">{{ articles.number }}
                </span>
                </a>
                </li>
            {% else %}
                <li >
                <a href="?page={{ p_num }}">
                    {{ p_num }}
                </a>
                </li>
            {% endif %}
        {% endif %}
    {% endfor %}
    
    
    {% if articles.has_next %}
        <li><a href="?page={{ articles.next_page_number }}">next</a></li>
    {% endif %}
</ul>
</div>
<div class="pagination">
<ul class="pagination">
    {% if articles.has_previous %}
        <li><a href="?page={{ articles.previous_page_number }}">&laquo;</a>
        </li>
    {% else %}
        <li class="disabled"><a href="?page={{ articles.next_page_number }}">&laquo;</a></li>
    {% endif %}

    {% for p_num in page_range %}
        {% if 0 < p_num and p_num < max_page %}
            {% if articles.number == p_num %}
                <li class="active">
                <a href="#">
                {{ articles.number }}
                <span class="sr-only">{{ articles.number }}
                </span>
                </a>
                </li>
            {% else %}
                <li >
                <a href="?page={{ p_num }}">
                    {{ p_num }}
                </a>
                </li>
            {% endif %}
        {% endif %}
    {% endfor %}


    {% if articles.has_next %}
        <li><a href="?page={{ articles.next_page_number }}">&raquo;</a></li>
        {% else %}
        <li class="disabled"><a href="?page={{ articles.next_page_number }}">&raquo;</a></li>
    {% endif %}
</ul>
</div>


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

刚察县| 友谊县| 军事| 宜昌市| 延安市| 环江| 阜康市| 岑巩县| 南川市| 邳州市| 漳州市| 元朗区| 舒城县| 嵊州市| 北京市| 永川市| 古浪县| 嘉兴市| 四子王旗| 杂多县| 女性| 基隆市| 乐安县| 苍南县| 新蔡县| 青海省| 夏河县| 措美县| 沾益县| 施秉县| 康马县| 永城市| 福鼎市| 新沂市| 应用必备| 文化| 敦煌市| 虞城县| 博湖县| 涟水县| 军事|