午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

主頁(yè) > 知識(shí)庫(kù) > Django Paginator分頁(yè)器的使用示例

Django Paginator分頁(yè)器的使用示例

熱門標(biāo)簽:高德地圖標(biāo)注是免費(fèi)的嗎 老人電話機(jī)器人 地圖標(biāo)注視頻廣告 北京電信外呼系統(tǒng)靠譜嗎 洪澤縣地圖標(biāo)注 大連crm外呼系統(tǒng) 無(wú)錫客服外呼系統(tǒng)一般多少錢 梅州外呼業(yè)務(wù)系統(tǒng) 百度地圖標(biāo)注位置怎么修改
# name: models.py
from django.db import models

class User(models.Model):
    id = models.AutoField(primary_key=True)
    username = models.CharField(max_length=32)
    password = models.CharField(max_length=32)

# 插入測(cè)試數(shù)據(jù)
import random
def index(request):
    for i in range(1,100):
        chars = []
        pasd = []
        for x in range(1,8):
            chars.append(random.choice('abcdefghijklmnopqrstuvwxyz'))
            pasd.append(random.choice('0987654321'))
        user = "".join(chars)
        pwd = "".join(pasd)
        models.User.objects.create(username=user, password=pwd)
    return HttpResponse("ok")
!--name: page.html-->
!DOCTYPE html>
html lang="en">
head>
    meta charset="UTF-8">
    title>Title/title>
     link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >
/head>
body>
table class="table table-sm table-hover">
    thead>
        tr class="table-success">
            th> 序號(hào)/th> th> 用戶名/th> th> 用戶密碼/th>
        /tr>
    /thead>
    tbody>
        {% for article in user_list %}
            tr class="table-primary">
                td>{{ article.id }}/td>
                td>{{ article.username }}/td>
                td>{{ article.password }}/td>
            /tr>
        {% endfor %}
    /tbody>
/table>
nav class="d-flex justify-content-center" aria-label="Page navigation example">
    ul class="pagination">
        li class="page-item">a class="page-link" href="./page?id=1" rel="external nofollow"  rel="external nofollow" >首頁(yè)/a>/li>
        {% if user_list.has_previous %}
            li class="page-item">a class="page-link" href="./page?id={{ user_list.previous_page_number }}" rel="external nofollow"  rel="external nofollow" >上一頁(yè)/a>/li>
        {% else %}
            li class="page-item disabled">a class="page-link" href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >上一頁(yè)/a>/li>
        {% endif %}

        {% for item in paginator.page_range %}
            {% if item == currentPage %}
                li class="page-item active">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% else %}
                li class="page-item">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% endif %}
        {% endfor %}

        {% if user_list.has_next %}
            li class="page-item">a class="page-link" href="./page?id={{ user_list.next_page_number }}" rel="external nofollow"  rel="external nofollow" >下一頁(yè)/a>/li>
        {% else %}
            li class="page-item disabled">a class="page-link" href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >下一頁(yè)/a>/li>
        {% endif %}
        li class="page-item">a class="page-link" href="./page?id={{ paginator.num_pages }}" rel="external nofollow"  rel="external nofollow" >尾頁(yè)/a>/li>
    /ul>
/nav>

div style="text-align: center;" class="alert alert-dark">
   統(tǒng)計(jì): {{ currentPage }}/{{ paginator.num_pages }} 共查詢到:{{ paginator.count }} 條數(shù)據(jù) 頁(yè)碼列表:{{ paginator.page_range }}
/div>
/body>
/html>
# name: views.py
from django.shortcuts import render,HttpResponse
from MyWeb import models
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

def page(request):
    user = models.User.objects.all()
    paginator = Paginator(user, 10)
    currentPage = int(request.GET.get("id",1))
    try:
        user_list = paginator.page(currentPage)
    except PageNotAnInteger:
        user_list = paginator.page(1)
    except:
        user_list = paginator.page(paginator.num_pages)

    return render(request,"page.html",{"user_list":user_list,
                                       "paginator":paginator,
                                       "currentPage":currentPage})
# name: urls.py
from MyWeb import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('page',views.page)
]

上方的分頁(yè)代碼還有一個(gè)不足之處,當(dāng)我們的頁(yè)碼數(shù)量過多時(shí),會(huì)全部展示出來(lái),整個(gè)頁(yè)面都是很不美觀,我們直接在上方代碼上稍加修改一下試試.

# name: views.py
from django.shortcuts import render,HttpResponse
from MyWeb import models
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

def page(request):
    user = models.User.objects.all()
    paginator = Paginator(user, 10)
    currentPage = int(request.GET.get("id",1))

    if paginator.num_pages > 15:
        if currentPage-5  1:
            pageRange = range(1,11)
        elif currentPage+5 > paginator.num_pages:
            pageRange = range(currentPage-5,paginator.num_pages)
        else:
            pageRange = range(currentPage-5,currentPage+5)
    else:
        pageRange = paginator.page_range

    try:
        user_list = paginator.page(currentPage)
    except PageNotAnInteger:
        user_list = paginator.page(1)
    except:
        user_list = paginator.page(paginator.num_pages)

    return render(request,"page.html",{"user_list":user_list,
                                       "paginator":paginator,
                                       "page_range":pageRange,        # 此處自定義一個(gè)分頁(yè)段
                                       "currentPage":currentPage})

前端分頁(yè)代碼只需要將paginator.page_range改為page_range其他地方不需要?jiǎng)?

        {% for item in page_range %}
            {% if item == currentPage %}
                li class="page-item active">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% else %}
                li class="page-item">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% endif %}
        {% endfor %}

這樣,無(wú)論有多少頁(yè)面,都能夠保證只顯示10頁(yè)。

分頁(yè)后添加刪除功能

1.刪除功能的實(shí)現(xiàn),很簡(jiǎn)單,只需要定位得到指定的tr上,取出里面的id號(hào)碼,并發(fā)送給后端,執(zhí)行sql刪除就完事了。

head>
    meta charset="UTF-8">
    title>Title/title>
     link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >
    script src="https://code.jquery.com/jquery-3.4.1.min.js">/script>
/head>
body>

script type="text/javascript">
    $(document).ready(function(){
      $("#but1").click(function(){
            var obj = $("#tab");          // 定位到table表格
            var check = $("table input[type=checkbox]:checked");
            check.each(function(){        // 遍歷節(jié)點(diǎn)
                var row = $(this).parent("td").parent("tr");  // 獲取選中行
                var id = row.find("[name='uid']").html();     // 取出第一行的屬性
                var name = row.find("[name='user']").html();
                alert("選中行的ID: " + id + "名字: " + name)
            });
      });
    });
/script>

table id="tab" class="table table-sm table-hover">
    thead>
        tr class="table-success">
            th>選擇/th>th> 序號(hào)/th> th> 用戶名/th> th> 用戶密碼/th>
        /tr>
    /thead>
    tbody>
        {% for article in user_list %}
            tr class="table-primary">
                td> input type="checkbox">/td>
                td name="uid">{{ article.id }}/td>
                td name="user">{{ article.username }}/td>
                td>{{ article.password }}/td>
            /tr>
        {% endfor %}
    /tbody>
/table>
.................

div>
    button id="but1" class="btn btn-danger" onclick="check()">刪除指定行/button>
/div>

實(shí)現(xiàn)模態(tài)框編輯內(nèi)容

點(diǎn)擊選中行,然后彈出模態(tài)框,并自動(dòng)的獲取到該行數(shù)據(jù),編輯好以后直接用ajax發(fā)送post請(qǐng)求到后端處理即可。

head>
    link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >
    script src="https://code.jquery.com/jquery-3.4.1.slim.min.js">/script>
    script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js">/script>
/head>

button type="button" id="but1" class="btn btn-success" data-toggle="modal" data-target="#staticBackdrop">彈框/button>

script type="text/javascript">
    $(document).ready(function(){
      $("#but1").click(function(){
            var obj = $("#tab");
            var edit = $("table input[type=checkbox]:checked");
            edit.each(function(){
                var row = $(this).parent("td").parent("tr");
                var id = row.find("[name='uid']").html();
                var name = row.find("[name='user']").html();
                var email = row.find("[name='email']").html();
                $("#edit_id").val(id);
                $("#edit_name").val(name);
                $("#edit_email").val(email);
            });
      });
    });
/script>
body>
table id="tab" border="1" cellspacing="0">
    thead>
        tr>
            th>選擇/th>th>用戶ID/th>th>用戶名稱/th>th>用戶郵箱/th>
        /tr>
    /thead>
    tbody>
        tr>
            td> input type="checkbox">/td>
            td name="uid"> 1001/td>
            td name="user"> lyshark/td>
            td name="email"> lyshark@123.com/td>
        /tr>
        tr>
            td> input type="checkbox">/td>
            td name="uid"> 1002/td>
            td name="user"> 搞事情/td>
            td name="email"> lyshark@123.com/td>
        /tr>
    /tbody>
/table>

div class="modal fade" id="staticBackdrop" data-backdrop="static" aria-hidden="true">
  div class="modal-dialog" role="document">
    div class="modal-content">
      div class="modal-header">
        h5 class="modal-title" id="staticBackdropLabel">編輯模式/h5>
      /div>
      div class="modal-body">
        !--主體部分-->
        div class="form-group row">
            label class="col-sm-2 col-form-label">用戶ID:/label>
            div class="col-sm-10">
              input type="text" id="edit_id" class="form-control">
            /div>

            label class="col-sm-2 col-form-label">名稱:/label>
            div class="col-sm-10">
              input type="text" id="edit_name" class="form-control">
            /div>

            label class="col-sm-2 col-form-label">郵箱:/label>
            div class="col-sm-10">
              input type="text" id="edit_email" class="form-control">
            /div>
        /div>
      /div>

      !--尾部?jī)?nèi)容-->
      div class="modal-footer">
        button type="button" class="btn btn-secondary" data-dismiss="modal">關(guān)閉/button>
        button type="button" class="btn btn-primary">提交數(shù)據(jù)/button>
      /div>
    /div>
  /div>
/body>

完整代碼筆記

利用BootStrap框架實(shí)現(xiàn)分頁(yè): 通過使用bootstrap框架,并配合Django自帶的分頁(yè)組件即可實(shí)現(xiàn)簡(jiǎn)單的分頁(yè)效果.

# name: models.py
from django.db import models

class User(models.Model):
    id = models.AutoField(primary_key=True)
    username = models.CharField(max_length=32)
    password = models.CharField(max_length=32)

# 插入測(cè)試數(shù)據(jù)
import random
def index(request):
    for i in range(1,1000):
        chars = []
        pasd = []
        for x in range(1,8):
            chars.append(random.choice('abcdefghijklmnopqrstuvwxyz'))
            pasd.append(random.choice('0987654321'))
        user = "".join(chars)
        pwd = "".join(pasd)
        models.User.objects.create(username=user, password=pwd)
    return HttpResponse("ok")
!--name: page.html-->
!DOCTYPE html>
html lang="en">
head>
    meta charset="UTF-8">
    title>Title/title>
     link rel="stylesheet"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >
/head>
body>
table class="table table-sm table-hover">
    thead>
        tr class="table-success">
            th> 序號(hào)/th> th> 用戶名/th> th> 用戶密碼/th>
        /tr>
    /thead>
    tbody>
        {% for article in user_list %}
            tr class="table-primary">
                td>{{ article.id }}/td>
                td>{{ article.username }}/td>
                td>{{ article.password }}/td>
            /tr>
        {% endfor %}
    /tbody>
/table>
nav class="d-flex justify-content-center" aria-label="Page navigation example">
    ul class="pagination">
        li class="page-item">a class="page-link" href="./page?id=1" rel="external nofollow"  rel="external nofollow" >首頁(yè)/a>/li>
        {% if user_list.has_previous %}
            li class="page-item">a class="page-link" href="./page?id={{ user_list.previous_page_number }}" rel="external nofollow"  rel="external nofollow" >上一頁(yè)/a>/li>
        {% else %}
            li class="page-item disabled">a class="page-link" href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >上一頁(yè)/a>/li>
        {% endif %}

        {% for item in paginator.page_range %}
            {% if item == currentPage %}
                li class="page-item active">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% else %}
                li class="page-item">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% endif %}
        {% endfor %}

        {% if user_list.has_next %}
            li class="page-item">a class="page-link" href="./page?id={{ user_list.next_page_number }}" rel="external nofollow"  rel="external nofollow" >下一頁(yè)/a>/li>
        {% else %}
            li class="page-item disabled">a class="page-link" href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >下一頁(yè)/a>/li>
        {% endif %}
        li class="page-item">a class="page-link" href="./page?id={{ paginator.num_pages }}" rel="external nofollow"  rel="external nofollow" >尾頁(yè)/a>/li>
    /ul>
/nav>

div style="text-align: center;" class="alert alert-dark">
   統(tǒng)計(jì): {{ currentPage }}/{{ paginator.num_pages }} 共查詢到:{{ paginator.count }} 條數(shù)據(jù) 頁(yè)碼列表:{{ paginator.page_range }}
/div>
/body>
/html>
# name: views.py
from django.shortcuts import render,HttpResponse
from MyWeb import models
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

def page(request):
    user = models.User.objects.all()
    paginator = Paginator(user, 10)
    currentPage = int(request.GET.get("id",1))
    try:
        user_list = paginator.page(currentPage)
    except PageNotAnInteger:
        user_list = paginator.page(1)
    except:
        user_list = paginator.page(paginator.num_pages)

    return render(request,"page.html",{"user_list":user_list,
                                       "paginator":paginator,
                                       "currentPage":currentPage})
# name: urls.py
from MyWeb import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('page',views.page)
]

上方的分頁(yè)代碼還有一個(gè)不足之處,當(dāng)我們頁(yè)面中的頁(yè)碼數(shù)量過多時(shí),默認(rèn)會(huì)將頁(yè)碼全部展示出來(lái),整個(gè)頁(yè)面看上去很不美觀,我們可以直接在上方分頁(yè)代碼上稍加修改即可,如下代碼.

# name: views.py
from django.shortcuts import render,HttpResponse
from MyWeb import models
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger

def page(request):
    user = models.User.objects.all()
    paginator = Paginator(user, 10)
    currentPage = int(request.GET.get("id",1))

    if paginator.num_pages > 15:
        if currentPage-5  1:
            pageRange = range(1,11)
        elif currentPage+5 > paginator.num_pages:
            pageRange = range(currentPage-5,paginator.num_pages)
        else:
            pageRange = range(currentPage-5,currentPage+5)
    else:
        pageRange = paginator.page_range

    try:
        user_list = paginator.page(currentPage)
    except PageNotAnInteger:
        user_list = paginator.page(1)
    except:
        user_list = paginator.page(paginator.num_pages)

    return render(request,"page.html",{"user_list":user_list,
                                       "paginator":paginator,
                                       "page_range":pageRange,        # 此處自定義一個(gè)分頁(yè)段
                                       "currentPage":currentPage})

前端分頁(yè)代碼只需要將paginator.page_range改為page_range其他地方不需要?jiǎng)?

        {% for item in page_range %}
            {% if item == currentPage %}
                li class="page-item active">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% else %}
                li class="page-item">a class="page-link" href="./page?id={{ item }}" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" >{{ item }}/a>/li>
            {% endif %}
        {% endfor %}

利用layui框架實(shí)現(xiàn)分頁(yè):

layui是一個(gè)完整的前端開發(fā)框架,利用它可以快速構(gòu)建分頁(yè)應(yīng)用,比BootStrap更加靈活.

# models.py
from django.db import models

class HostDB(models.Model):
    id = models.AutoField(primary_key=True)
    hostname = models.CharField(max_length=64)
    hostaddr = models.CharField(max_length=64)
    hostmode = models.CharField(max_length=64)
!--name: index.html-->
!DOCTYPE html>
html lang="en">
head>
    meta charset="UTF-8">
    link rel="stylesheet"  rel="external nofollow"  rel="external nofollow" >
    script type="text/javascript" src="https://lyshark.com/cdn/layui/layui.js">/script>
/head>
body>
table class="layui-hide" id="demo">/table>

    script type="text/javascript">
    layui.use('table', function(){
      var table = layui.table;
      table.render({
          elem: '#demo',
          url:'/get_page',
          method:'get',
          toolbar: '#toolbarDemo'         // 顯示工具條
          ,request: {
                  pageName: 'pageIndex',  // 頁(yè)碼的參數(shù)名稱,默認(rèn):page
                  limitName: 'pageSize'   // 每頁(yè)數(shù)據(jù)量的參數(shù)名,默認(rèn):limit
          }
          ,response: {
                  statusName: 'code',     // 規(guī)定數(shù)據(jù)狀態(tài)的字段名稱,默認(rèn):code
                  statusCode: 0,          // 規(guī)定成功的狀態(tài)碼,默認(rèn):0
                  msgName: 'msg',         // 規(guī)定狀態(tài)信息的字段名稱,默認(rèn):msg
                  countName: 'DataCount', // 規(guī)定數(shù)據(jù)總數(shù)的字段名稱,默認(rèn):count
                  dataName: 'data'        // 規(guī)定數(shù)據(jù)列表的字段名稱,默認(rèn):data
          }
        ,cols: [[
          {type: 'checkbox', fixed: 'left'},
          {field:'id', title:'主機(jī)ID', width:100, sort: true},
          {field:'hostname', title:'主機(jī)名稱', width:120},
          {field:'hostaddr', title:'主機(jī)地址', width:120},
          {field:'hostmode', title:'主機(jī)組', width:120},
        ]]
        ,page: {
            layout: ['limit', 'count', 'prev', 'page', 'next', 'skip'],     // 自定義分頁(yè)布局
            curr: 1,      // 設(shè)置默認(rèn)起始頁(yè)1
            groups: 10,   //只顯示10個(gè)連續(xù)頁(yè)碼,就是說(shuō)顯示10個(gè)可見頁(yè)其他的省略
            first: false, // 不顯示首頁(yè)
            last: false   // 不顯示尾頁(yè)
        },
        limit: 5,
        limits: [5,10,15,20,25]
      });
    });
    /script>
/body>
/html>
# views.py

from django.shortcuts import render,HttpResponse
from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger
from MyWeb import models
import json

def index(request):
    return render(request,"index.html")

def get_page(request):
    data = models.HostDB.objects.all()
    dataCount = data.count()
    pageIndex = request.GET.get("pageIndex")
    pageSize = request.GET.get("pageSize")
    print("當(dāng)前索引:{} 當(dāng)前大小:{}".format(pageIndex,pageSize))
    print("所有記錄:{} 數(shù)據(jù)總條數(shù):{}".format(data,dataCount))

    # 將數(shù)據(jù)組裝成字典后放入data_list列表
    data_list,ref_data = [],[]
    for item in data:
        dict = { 'id':item.id , 'hostname':item.hostname, 'hostaddr':item.hostaddr, 'hostmode':item.hostmode }
        data_list.append(dict)

    # 使用分頁(yè)器分頁(yè)
    pageInator = Paginator(data_list,pageSize)
    context = pageInator.page(pageIndex)
    for item in context:
        ref_data.append(item)
    # 返回分頁(yè)格式
    data = { "code": 0,"msg": "ok","DataCount": dataCount,"data": ref_data }
    return HttpResponse(json.dumps(data))
# name: url.py
from MyWeb import views

urlpatterns = [
    path('admin/', admin.site.urls),
    path('',views.index),
    path('get_page/',views.get_page)
]

layui實(shí)現(xiàn)完整表格分頁(yè):

通過使用layui框架完成的一個(gè)相對(duì)完整的表格分頁(yè),可用于生產(chǎn)環(huán)境.

!--name: index.html-->
!DOCTYPE html>
html lang="en">
head>
    meta charset="UTF-8">
    link rel="stylesheet"  rel="external nofollow"  rel="external nofollow" >
    script type="text/javascript" src="https://lyshark.com/cdn/jquery/jquery3.js">/script>
    script type="text/javascript" src="https://lyshark.com/cdn/layui/layui.js">/script>
/head>
body>
div class="demoTable">
    div class="layui-inline">
        input class="layui-input" name="id" id="demoReload" autocomplete="off">
    /div>
        button class="layui-btn" data-type="reload">搜索/button>
/div>

script type="text/html" id="barDemo">
  a class="layui-btn layui-btn-xs" lay-event="edit">編輯/a>
  a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">刪除/a>
/script>

table class="layui-hide" id="demo" lay-filter="test">/table>

    script type="text/javascript">
    layui.use('table', function(){
      var table = layui.table;
      table.render({
          elem: '#demo',
          id: 'testReload',
          url:'/get_page',
          method:'get'
          ,request: {
                  pageName: 'pageIndex',  // 頁(yè)碼的參數(shù)名稱,默認(rèn):page
                  limitName: 'pageSize'   // 每頁(yè)數(shù)據(jù)量的參數(shù)名,默認(rèn):limit
          }
          ,response: {
                  statusName: 'code',     // 規(guī)定數(shù)據(jù)狀態(tài)的字段名稱,默認(rèn):code
                  statusCode: 0,          // 規(guī)定成功的狀態(tài)碼,默認(rèn):0
                  msgName: 'msg',         // 規(guī)定狀態(tài)信息的字段名稱,默認(rèn):msg
                  countName: 'DataCount', // 規(guī)定數(shù)據(jù)總數(shù)的字段名稱,默認(rèn):count
                  dataName: 'data'        // 規(guī)定數(shù)據(jù)列表的字段名稱,默認(rèn):data
          }
        ,cols: [[
          {type: 'checkbox', fixed: 'left'},
          {field:'id', title:'主機(jī)ID', width:100, sort: true},
          {field:'hostname', title:'主機(jī)名稱', width:120},
          {field:'hostaddr', title:'主機(jī)地址', width:120},
          {field:'hostmode', title:'主機(jī)組', width:120},
          {fixed: 'right', title:'操作', toolbar: '#barDemo', width:120}
        ]]
        ,page: {
            layout: ['limit', 'count', 'prev', 'page', 'next', 'skip'],     // 自定義分頁(yè)布局
            curr: 1,      // 設(shè)置默認(rèn)起始頁(yè)1
            groups: 10,   // 只顯示10個(gè)連續(xù)頁(yè)碼,就是說(shuō)顯示10個(gè)可見頁(yè)其他的省略
            first: false, // 不顯示首頁(yè)
            last: false   // 不顯示尾頁(yè)
        },
        limit: 5,
        limits: [5,10,15,20,25]
      });
// ------------------------------------------------------------------
// 監(jiān)聽行工具事件:也就是編輯與刪除的處理事件
      table.on('tool(test)', function(obj){
        var data = obj.data;
        if(obj.event === 'del'){
          layer.confirm('真的要?jiǎng)h除本行數(shù)據(jù)嗎 ?', {icon: 3,anim: 2}, function(index){
            // console.log("待刪除ID: " + obj.data['id']);
           $.ajax({
               url:"/delete_page/",
               type:"get",
               data: {"id":obj.data['id']},
               success:function (recv) {
                   layer.msg("刪除完成了..", {icon: 6});
               }
           });
            obj.del();
            layer.close(index);
          });
        } else if(obj.event === 'edit'){
          layer.prompt({ formType:2, title: "編輯表格",btn:['修改數(shù)據(jù)','關(guān)閉'],anim: 4,
              content:`div>
                            主機(jī)序號(hào): input type="text" style='display:inline-block' id="id">br>br>
                            主機(jī)名稱: input type="text" style='display:inline-block' id="hostname">br>br>
                            主機(jī)地址: input type="text" style='display:inline-block' id="hostaddr">br>br>
                            主機(jī)屬組: input type="text" style='display:inline-block' id="hostmode">br>br>
                       /div>`,
              yes:function (index,layero)
              {
                  console.log("點(diǎn)擊yes觸發(fā)事件:" + index);
                  var id = $("#id").val();
                  var hostname = $("#hostname").val();
                  var hostaddr = $("#hostaddr").val();
                  var hostmode = $("#hostmode").val();
                  $.ajax({
                      url: "/update_page",
                      type: "get",
                      data: {"id": id,
                              "hostname": hostname,
                              "hostaddr": hostaddr,
                              "hostmode": hostmode },
                      success:function (recv) {
                        // 修改完成后,本地直接更新數(shù)據(jù),這樣就無(wú)需刷新一次了
                          obj.update({
                              hostname: hostname,
                              hostaddr: hostaddr,
                              hostmode: hostmode
                          });
                          layer.msg("修改完成了..", {icon: 6});
                          layer.close(index);
                      }
                  });
              }
          });
              $("#id").val(data.id);
              $("#hostname").val(data.hostname);
              $("#hostaddr").val(data.hostaddr);
              $("#hostmode").val(data.hostmode);
        }
      });

        // 搜索后的重載,也就是找到數(shù)據(jù)以后直接更新
      var $ = layui.$, active = {
        reload: function(){
          var demoReload = $('#demoReload');
          //執(zhí)行重載
          table.reload('testReload', {
            url:"/search_page",
            page: {
              curr: 1,
              limits: [1]
            }
            ,where: {
                hostname: demoReload.val()
            }
          });
        }
      };
    // ---------------------------------------------------------
    // 綁定搜索事件
      $('.demoTable .layui-btn').on('click', function(){
            var type = $(this).data('type');
            active[type] ? active[type].call(this) : '';
          });
    });
    /script>
/body>
/html>
# name:views.py

from django.shortcuts import render,HttpResponse
from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger
from MyWeb import models
import json

def index(request):
    return render(request,"index.html")

def get_page(request):
    data = models.HostDB.objects.all()
    dataCount = data.count()
    pageIndex = request.GET.get("pageIndex")
    pageSize = request.GET.get("pageSize")
    print("當(dāng)前索引:{} 當(dāng)前大小:{}".format(pageIndex,pageSize))
    print("所有記錄:{} 數(shù)據(jù)總條數(shù):{}".format(data,dataCount))

    list = []
    res = []
    for item in data:
        dict = {}
        dict['id'] = item.id
        dict['hostname'] = item.hostname
        dict['hostaddr'] = item.hostaddr
        dict['hostmode'] = item.hostmode
        list.append(dict)

    pageInator = Paginator(list,pageSize)
    context = pageInator.page(pageIndex)
    for item in context:
        res.append(item)
    data = { "code": 0,"msg": "ok","DataCount": dataCount,"data": res }
    return HttpResponse(json.dumps(data))

def search_page(request):
    sql = request.GET.get("hostname")
    data = models.HostDB.objects.all().filter(hostname=sql)
    list = []
    for item in data:
        dict = {}
        dict['id'] = item.id
        dict['hostname'] = item.hostname
        dict['hostaddr'] = item.hostaddr
        dict['hostmode'] = item.hostmode
        list.append(dict)

    data = { "code": 0,"msg": "ok","DataCount": 1,"data": list }
    return HttpResponse(json.dumps(data))

def delete_page(request):
    get_id = request.GET.get("id")
    models.HostDB.objects.filter(id=get_id).delete()
    return render(request,"index.html")

def update_page(request):
    get_id = request.GET.get("id")
    get_hostname = request.GET.get("hostname")
    get_hostaddr = request.GET.get("hostaddr")
    get_hostmode = request.GET.get("hostmode")

    print(get_hostmode)
    obj = models.HostDB.objects.get(id=get_id)
    obj.hostname = get_hostname
    obj.hostaddr = get_hostaddr
    obj.hostmode = get_hostmode
    obj.save()
    return render(request,"index.html")
# name: urls.py

from MyWeb import views

urlpatterns = [
    path('',views.index),
    path('get_page/',views.get_page),
    path('search_page/',views.search_page),
    path('delete_page/',views.delete_page),
    path("update_page/",views.update_page)
]

自己實(shí)現(xiàn)分頁(yè):

轉(zhuǎn)載代碼,僅用于收藏。

from urllib.parse import urlencode

class Pagination(object):
    def __init__(self,current_page,total_count,base_url,params,per_page_count=10,max_pager_count=10):
        try:
            current_page = int(current_page)
        except Exception as e:
            current_page = 1
        if current_page = 1:
            current_page = 1
        self.current_page = current_page
        # 數(shù)據(jù)總條數(shù)
        self.total_count = total_count

        # 每頁(yè)顯示10條數(shù)據(jù)
        self.per_page_count = per_page_count

        # 頁(yè)面上應(yīng)該顯示的最大頁(yè)碼
        max_page_num, div = divmod(total_count, per_page_count)
        if div:
            max_page_num += 1
        self.max_page_num = max_page_num

        # 頁(yè)面上默認(rèn)顯示11個(gè)頁(yè)碼(當(dāng)前頁(yè)在中間)
        self.max_pager_count = max_pager_count
        self.half_max_pager_count = int((max_pager_count - 1) / 2)

        # URL前綴
        self.base_url = base_url

        # request.GET
        import copy
        params = copy.deepcopy(params)
        # params._mutable = True
        get_dict = params.to_dict()
        # 包含當(dāng)前列表頁(yè)面所有的搜/索條件
        self.params = get_dict

    @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

    def page_html(self):
        # 如果總頁(yè)數(shù) = 11
        if self.max_page_num = self.max_pager_count:
            pager_start = 1
            pager_end = self.max_page_num
        # 如果總頁(yè)數(shù) > 11
        else:
            # 如果當(dāng)前頁(yè) = 5
            if self.current_page = self.half_max_pager_count:
                pager_start = 1
                pager_end = self.max_pager_count
            else:
                # 當(dāng)前頁(yè) + 5 > 總頁(yè)碼
                if (self.current_page + self.half_max_pager_count) > self.max_page_num:
                    pager_end = self.max_page_num
                    pager_start = self.max_page_num - self.max_pager_count + 1   #倒這數(shù)11個(gè)
                else:
                    pager_start = self.current_page - self.half_max_pager_count
                    pager_end = self.current_page + self.half_max_pager_count

        page_html_list = []
        # {source:[2,], status:[2], gender:[2],consultant:[1],page:[1]}
        # 首頁(yè)
        self.params['page'] = 1
        first_page = '首頁(yè)' % (self.base_url,urlencode(self.params),)
        page_html_list.append(first_page)
        # 上一頁(yè)
        self.params["page"] = self.current_page - 1
        if self.params["page"] = 1:
            pervious_page = '上一頁(yè)' % (self.base_url, urlencode(self.params))
        else:
            pervious_page = '上一頁(yè)' % ( self.base_url, urlencode(self.params))
        page_html_list.append(pervious_page)
        # 中間頁(yè)碼
        for i in range(pager_start, pager_end + 1):
            self.params['page'] = i
            if i == self.current_page:
                temp = '%s' % (self.base_url,urlencode(self.params), i,)
            else:
                temp = '%s' % (self.base_url,urlencode(self.params), i,)
            page_html_list.append(temp)

        # 下一頁(yè)
        self.params["page"] = self.current_page + 1
        if self.params["page"] > self.max_page_num:
            self.params["page"] = self.current_page
            next_page = '下一頁(yè)' % (self.base_url, urlencode(self.params))
        else:
            next_page = '下一頁(yè)' % (self.base_url, urlencode(self.params))
        page_html_list.append(next_page)

        # 尾頁(yè)
        self.params['page'] = self.max_page_num
        last_page = '尾頁(yè)' % (self.base_url, urlencode(self.params),)
        page_html_list.append(last_page)

        return ''.join(page_html_list)

文章出處:https://www.cnblogs.com/lyshark

以上就是Django Paginator分頁(yè)器的使用示例的詳細(xì)內(nèi)容,更多關(guān)于Django Paginator分頁(yè)器的使用的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

您可能感興趣的文章:
  • Django1.11自帶分頁(yè)器paginator的使用方法
  • django的分頁(yè)器Paginator 從django中導(dǎo)入類
  • Django的分頁(yè)器實(shí)例(paginator)
  • 三步實(shí)現(xiàn)Django Paginator分頁(yè)的方法
  • Django使用paginator插件實(shí)現(xiàn)翻頁(yè)功能的實(shí)例
  • Django原生sql也能使用Paginator分頁(yè)的示例代碼
  • Django drf分頁(yè)器的使用詳解
  • Django分頁(yè)器的用法詳解
  • Django分頁(yè)器的用法你都了解嗎
  • Django 自定義分頁(yè)器的實(shí)現(xiàn)代碼

標(biāo)簽:長(zhǎng)春 泉州 岳陽(yáng) 清遠(yuǎn) 安慶 吉林 洛陽(yáng) 怒江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Django Paginator分頁(yè)器的使用示例》,本文關(guān)鍵詞  Django,Paginator,分頁(yè),器,的,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Django Paginator分頁(yè)器的使用示例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于Django Paginator分頁(yè)器的使用示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    日韩中文视频免费在线观看| 国内自拍欧美激情| 丝袜亚洲另类欧美| 天堂网中文在线观看| 日韩精品一区二区视频| 国产精品久久久久影院| 婷婷五月综合激情| 日韩影院一区二区| 亚洲小视频网站| 欧美视频小说| 青青草原一区二区| 日韩国产激情在线| 激情成人中文字幕| 99精品视频中文字幕| 综合久久中文字幕| 国产调教在线观看| 精品久久久久久中文字幕2017| 国模精品娜娜一二三区| 日韩有码在线电影| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 久久婷婷成人综合色| 色综合久久久久久| 国产亚洲精品码| 国产免费a级片| 少妇人妻在线视频| 久久久久久久久久久久久久一区| 97视频国产在线| 日韩电影免费观看在线观看| 五月天丁香花婷婷| 国产极品美女高潮无套久久久| 午夜免费福利视频在线观看| 久久日免费视频| 国产喷水福利在线视频| 搡老岳熟女国产熟妇| 尤蜜粉嫩av国产一区二区三区| a级国产乱理论片在线观看99| 精品国产一区二区在线| 欧美一级日韩不卡播放免费| 一片黄亚洲嫩模| 91天堂素人约啪| 久久中文欧美| 中文字幕91爱爱| 日韩av手机在线免费观看| 色偷偷中文字幕| 欧美日韩性生活片| 亚洲 国产 欧美一区| 国产欧美日韩成人| 一级做a爱片久久| 午夜精品一区二区三区视频免费看| 91国产中文字幕| 波多野结衣办公室双飞| 日本一极黄色片| 性生活视频软件| 日韩av在线看| 国产女人18毛片水18精品| 在线观看欧美激情| 久久久久无码精品| 伊人免费在线观看高清版| 欧美国产成人精品| 亚洲片在线资源| 91福利入口| 久久www视频| 国产艳妇疯狂做爰视频| 这里只有久久精品视频| 国产精品毛片久久久久久| 亚洲国产精久久久久久久| 精品国产欧美日韩不卡在线观看| 日日噜噜噜噜久久久精品毛片| 欧洲金发美女大战黑人| 欧美日韩免费精品| 国产精品一区二区三区不卡| 国产精品色婷婷视频| 韩剧1988免费观看全集| 伦伦影院午夜日韩欧美限制| 精品日产卡一卡二卡麻豆| 欧美偷拍一区二区| 欧美性20hd另类| 一区二区在线观看免费| 亚洲欧洲国产专区| 国产欧美va欧美不卡在线| 99精品在线观看视频| 国产精品夜夜嗨| 亚洲av成人无码网天堂| 国产刺激高潮av| 国产白浆在线观看| 狠狠躁夜夜躁人人爽视频| 欧美第一页在线观看| 任你操精品视频| 三区四区在线观看| 久久久久无码国产精品一区李宗瑞 | 91国产免费看| 国内精品小视频| 欧美日韩在线不卡视频| 老熟妇一区二区三区| 亚洲国产精品麻豆| 国产成一区二区| 日本人视频jizz页码69| 国产一区二区在线视频| 黄色一级片在线| 日本高清一二三区| 国产一二三四区| 免费又黄又爽又色的视频| 国产一二三四区| 五月天丁香激情| 日韩成人高清视频| 国产一级淫片a| 三级黄色在线视频| 日本特级黄色片| 国产又粗又爽视频| 亚洲 国产 日韩 欧美| 中文字幕一区二区人妻痴汉电车| 在线观看免费高清视频| 欧美日韩 一区二区三区| 欧美成人一区二区三区四区| 欧美成人一区二区视频| 国产又大又粗又长| 狠狠综合久久av一区二区| a级片免费观看| 欧美一级一区二区三区| 视频在线观看一区二区三区| 毛片基地黄久久久久久天堂| 国内成人精品2018免费看| 视频一区二区不卡| 国产在线精品免费| 91在线精品秘密一区二区| 国产欧美日韩另类一区| 亚洲精品日韩综合观看成人91| 亚洲福利视频一区二区| 色婷婷精品久久二区二区蜜臂av | 欧美在线视频观看| 国产精品视频区| 国产99视频精品免费视频36| 久久久精品国产一区二区三区| 污视频在线免费观看一区二区三区| 性生活免费观看视频| 欧美 国产 日本| 91性高潮久久久久久久| 久久久亚洲av波多野结衣| 国产午夜精品理论片在线| 久久婷婷国产麻豆91| 五月激情丁香网| 亚洲一区在线观| 污视频网站免费观看| 狠狠色丁香婷婷综合久久片| 92国产精品观看| 国产乱码精品一区二三区蜜臂| 欧美特黄一级视频| 国产精品18久久久久| 91麻豆国产在线观看| 中文字幕一区二区三区av| 亚洲h动漫在线| 欧美一级日韩不卡播放免费| 日韩中文在线中文网三级| 欧美日韩电影在线观看| 国产欧美亚洲视频| 欧美乱偷一区二区三区在线| 成人黄色大片网站| 国产裸体视频网站| 大又大又粗又硬又爽少妇毛片| 久久久国产成人| 一级特黄aa大片| 蜜臀av性久久久久蜜臀av麻豆| 99久久亚洲一区二区三区青草| 国产精品妹子av| 亚洲精品久久久久久国产精华液| 欧美天天综合网| 一区二区在线免费视频| 久久久久久国产| 国产91精品入口17c| 免费看国产精品一二区视频| 国产成人艳妇aa视频在线 | 天堂av手机版| www.av亚洲| 亚洲成av人片在线观看无码| 欧美揉bbbbb揉bbbbb| 在线国产精品播放| 日韩免费黄色av| 亚洲 国产 欧美一区| 奇米777四色影视在线看| 国内av免费观看| 欧美在线视频第一页| a天堂在线观看视频| 国产成人午夜电影网| 国产精品蜜臀av| 欧美一级淫片007| 欧美极品xxxx| 黄色国产精品一区二区三区| 一级一片免费播放| 秋霞午夜鲁丝一区二区 | 日韩有码第一页| 国产欧美精品一区二区三区四区| 91.com视频| 91精品国产91久久| 日韩国产精品一区二区| 久久综合在线观看| 久久久无码一区二区三区| jlzzjlzzjlzz亚洲人| 成人中文字幕合集| 色婷婷精品久久二区二区蜜臀av| 日韩中文字幕精品| 国产激情一区二区三区在线观看 | 国产成人aa精品一区在线播放 | 精品区一区二区| 欧美一区二区视频97| 亚洲五月六月| 日本wwwwwww| 日本丰满少妇做爰爽爽| 国产成人自拍网| 色先锋资源久久综合| 免费91在线视频| 欧美日韩在线精品| 中文字幕 欧美 日韩| 亚洲国产精品无码久久久| 国产在线视频不卡二| 精品日本高清在线播放| 爱福利视频一区| 麻豆av一区二区三区| 日本少妇一级片| 国产精品第6页| 99久久精品国产麻豆演员表| 欧美日韩精品一区二区在线播放| 国模吧一区二区三区| 一区二区视频在线免费| 女尊高h男高潮呻吟| 在线免费a视频| 久久新电视剧免费观看| 精品国产91久久久久久久妲己 | 欧美高清性xxxx| 国产露脸91国语对白| 国产精品女同一区二区三区| 亚洲第一网中文字幕| 91免费看国产| 污网站在线免费| 国产免费一区二区三区四区五区| 成人18视频在线播放| 欧美一区二区免费观在线| 97色在线视频| 啊啊啊一区二区| 精品少妇久久久| 国产精品一二三四| 欧美一区二区视频观看视频| 成人精品一区二区三区电影免费| 99久久激情视频| 伊人手机在线视频| 91免费观看视频| 欧美一区二区三级| 国产高清不卡av| www.美色吧.com| 女人18毛片一区二区三区| 亚洲自拍另类综合| 97国产在线观看| 日本在线xxx| 日韩一区二区视频在线| 91免费观看视频| 综合欧美国产视频二区| 神马影院一区二区| 国产精品20p| 精品一区二区三区影院在线午夜 | 欧美成人午夜视频| 亚洲一区二区三区免费看| 粉嫩精品久久99综合一区| 青娱乐精品视频在线| 欧美色手机在线观看| 国产区精品视频| 亚洲欧美日韩精品一区| 国产乱淫av片免费| 国产精品夫妻自拍| 久久视频在线视频| 日韩激情视频一区二区| 一级aaa毛片| 国产人成亚洲第一网站在线播放| 黄色污污网站在线观看| 韩国女主播成人在线| 欧美一区二区三区影视| 亚洲专区中文字幕| 男人操女人下面视频| www.日韩高清| 天天色 色综合| 国产精品入口福利| 久久久精品麻豆| 亚洲性在线观看| 亚洲免费三区一区二区| 日韩中文字幕网| 一卡二卡三卡视频| 精品免费囯产一区二区三区| 国产精品午夜久久| 欧美日韩999| 国产视频一区二区三区在线播放| 国产又粗又长又黄| 欧美性猛交xxxx富婆弯腰| 国产精品1区2区在线观看| 少妇av一区二区三区无码| 真实新婚偷拍xxxxx| 亚洲色大成网站www久久九九| 精品自在线视频| 国产97在线 | 亚洲| 欧美日韩一区在线观看| wwwwxxxxx欧美| 亚洲女成人图区| 日韩久久久久久久| 国产亚洲成人av| 中文字幕一区二区三区四区| 国内伊人久久久久久网站视频| 欧美在线观看黄| 一级aaaa毛片| 欧美性猛交xxxx久久久| 成人做爽爽免费视频| 日韩网站在线播放| 不卡一区在线观看| 久久精品国产久精国产一老狼| 久久国产亚洲精品无码| 精品人妻无码一区二区三区蜜桃一 | 国语自产在线不卡| 国产精品无码一本二本三本色| 免费又黄又爽又猛大片午夜| 午夜亚洲国产au精品一区二区| 国产一区二区香蕉| 在线免费观看a级片| 成人午夜伦理影院| 久久国产精品影视| 国产精欧美一区二区三区白种人| 日韩av电影免费观看| 欧美精品久久久久久久久46p| 26uuu精品一区二区三区四区在线| 久久精品久久久久电影| 欧美性大战久久久久xxx| www.日日夜夜| 日韩精品一区二区在线观看| 欧美日韩成人一区二区三区 | 五月天激情四射| 午夜精品免费在线| 久久久久久久久久久久久久久久av | 国产乱码久久久久久| 午夜精品视频一区| 国产一区二区精品在线| 国产黄色片视频| 亚洲成av人影院| 免费一区二区三区| 日韩精品手机在线| 日本福利一区二区| 亚洲精美视频| 一级片在线免费观看视频| 日韩天堂在线观看| 永久免费网站视频在线观看| 国产激情久久久久久熟女老人av| 欧美一级二级在线观看| 波多野结衣av一区二区全免费观看| 亚洲第一视频在线| 日韩电影在线观看中文字幕 | 蜜臀av免费在线观看| 日韩精品中文字幕在线观看 | 国产精品国三级国产av| 国产一区二区在线视频观看| 欧美妇女性影城| 日韩精品一区二区三区四| 秋霞av鲁丝片一区二区| 国产亚洲成av人片在线观看桃| 中文字幕永久视频| 成人av网在线| 国产不卡av在线免费观看| 亚洲一区 欧美| 国产精品第四页| 成人欧美一区二区三区黑人免费| 二区视频在线观看| 欧美喷水一区二区| 国产一线二线三线女| 国产精品午夜福利| 国产视频久久网| 国产伦精品一区二区三区妓女下载| av毛片久久久久**hd| 国产日韩欧美黄色| 亚洲欧美小视频| 91黄色免费网站| 日本一道在线观看| 久久久久国产精品一区三寸| 日韩在线免费视频| 亚洲欧美手机在线| 国产午夜一区二区三区| 99视频国产精品免费观看| 亚洲AV无码成人精品区东京热| 日韩欧美在线123| 欧日韩免费视频| 国产精品系列在线观看| 国产成人亚洲综合| 久久午夜无码鲁丝片午夜精品| 欧美日韩国产区一| 日本黄xxxxxxxxx100| 青青草成人在线观看| 欧美整片在线观看| 免费一级片视频| 日韩一区二区三免费高清| 免费看黄在线看| 成人网男人的天堂| 91精品天堂| 一起草av在线| 日韩专区中文字幕| www.88av| 偷窥少妇高潮呻吟av久久免费| 蜜臀av.com| 极品美女销魂一区二区三区| 91tv亚洲精品香蕉国产一区7ujn| 91精品少妇一区二区三区蜜桃臀| 色婷婷久久久久swag精品| 亚洲综合第一| 亚洲av无码乱码在线观看性色| 久久久国产成人精品| 国产美女永久免费无遮挡| 在线看国产日韩| 成人在线免费播放视频| 国产欧美精品区一区二区三区|