亚洲综合原千岁中文字幕_国产精品99久久久久久久vr_无码人妻aⅴ一区二区三区浪潮_成人h动漫精品一区二区三

<big id="jrdf4"><sup id="jrdf4"><small id="jrdf4"></small></sup></big>
<rt id="jrdf4"><video id="jrdf4"><rt id="jrdf4"></rt></video></rt>
    • <kbd id="jrdf4"></kbd>
      <ins id="jrdf4"><div id="jrdf4"><tfoot id="jrdf4"></tfoot></div></ins>
      <small id="jrdf4"><div id="jrdf4"></div></small>
      <ins id="jrdf4"><sup id="jrdf4"><nobr id="jrdf4"></nobr></sup></ins>
      主頁 > 知識庫 > Django Paginator分頁器的使用示例

      Django Paginator分頁器的使用示例

      熱門標簽:高德地圖標注是免費的嗎 老人電話機器人 地圖標注視頻廣告 北京電信外呼系統靠譜嗎 洪澤縣地圖標注 大連crm外呼系統 無錫客服外呼系統一般多少錢 梅州外呼業務系統 百度地圖標注位置怎么修改
      # 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)
      
      # 插入測試數據
      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> 序號/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" >首頁/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" >上一頁/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" >上一頁/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" >下一頁/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" >下一頁/a>/li>
              {% endif %}
              li class="page-item">a class="page-link" href="./page?id={{ paginator.num_pages }}" rel="external nofollow"  rel="external nofollow" >尾頁/a>/li>
          /ul>
      /nav>
      
      div style="text-align: center;" class="alert alert-dark">
         統計: {{ currentPage }}/{{ paginator.num_pages }} 共查詢到:{{ paginator.count }} 條數據 頁碼列表:{{ 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)
      ]

      上方的分頁代碼還有一個不足之處,當我們的頁碼數量過多時,會全部展示出來,整個頁面都是很不美觀,我們直接在上方代碼上稍加修改一下試試.

      # 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,        # 此處自定義一個分頁段
                                             "currentPage":currentPage})

      前端分頁代碼只需要將paginator.page_range改為page_range其他地方不需要動.

              {% 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 %}

      這樣,無論有多少頁面,都能夠保證只顯示10頁。

      分頁后添加刪除功能

      1.刪除功能的實現,很簡單,只需要定位得到指定的tr上,取出里面的id號碼,并發送給后端,執行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(){        // 遍歷節點
                      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> 序號/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>

      實現模態框編輯內容

      點擊選中行,然后彈出模態框,并自動的獲取到該行數據,編輯好以后直接用ajax發送post請求到后端處理即可。

      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>
      
            !--尾部內容-->
            div class="modal-footer">
              button type="button" class="btn btn-secondary" data-dismiss="modal">關閉/button>
              button type="button" class="btn btn-primary">提交數據/button>
            /div>
          /div>
        /div>
      /body>

      完整代碼筆記

      利用BootStrap框架實現分頁: 通過使用bootstrap框架,并配合Django自帶的分頁組件即可實現簡單的分頁效果.

      # 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)
      
      # 插入測試數據
      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> 序號/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" >首頁/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" >上一頁/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" >上一頁/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" >下一頁/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" >下一頁/a>/li>
              {% endif %}
              li class="page-item">a class="page-link" href="./page?id={{ paginator.num_pages }}" rel="external nofollow"  rel="external nofollow" >尾頁/a>/li>
          /ul>
      /nav>
      
      div style="text-align: center;" class="alert alert-dark">
         統計: {{ currentPage }}/{{ paginator.num_pages }} 共查詢到:{{ paginator.count }} 條數據 頁碼列表:{{ 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)
      ]

      上方的分頁代碼還有一個不足之處,當我們頁面中的頁碼數量過多時,默認會將頁碼全部展示出來,整個頁面看上去很不美觀,我們可以直接在上方分頁代碼上稍加修改即可,如下代碼.

      # 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,        # 此處自定義一個分頁段
                                             "currentPage":currentPage})

      前端分頁代碼只需要將paginator.page_range改為page_range其他地方不需要動.

              {% 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框架實現分頁:

      layui是一個完整的前端開發框架,利用它可以快速構建分頁應用,比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',  // 頁碼的參數名稱,默認:page
                        limitName: 'pageSize'   // 每頁數據量的參數名,默認:limit
                }
                ,response: {
                        statusName: 'code',     // 規定數據狀態的字段名稱,默認:code
                        statusCode: 0,          // 規定成功的狀態碼,默認:0
                        msgName: 'msg',         // 規定狀態信息的字段名稱,默認:msg
                        countName: 'DataCount', // 規定數據總數的字段名稱,默認:count
                        dataName: 'data'        // 規定數據列表的字段名稱,默認:data
                }
              ,cols: [[
                {type: 'checkbox', fixed: 'left'},
                {field:'id', title:'主機ID', width:100, sort: true},
                {field:'hostname', title:'主機名稱', width:120},
                {field:'hostaddr', title:'主機地址', width:120},
                {field:'hostmode', title:'主機組', width:120},
              ]]
              ,page: {
                  layout: ['limit', 'count', 'prev', 'page', 'next', 'skip'],     // 自定義分頁布局
                  curr: 1,      // 設置默認起始頁1
                  groups: 10,   //只顯示10個連續頁碼,就是說顯示10個可見頁其他的省略
                  first: false, // 不顯示首頁
                  last: false   // 不顯示尾頁
              },
              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("當前索引:{} 當前大小:{}".format(pageIndex,pageSize))
          print("所有記錄:{} 數據總條數:{}".format(data,dataCount))
      
          # 將數據組裝成字典后放入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)
      
          # 使用分頁器分頁
          pageInator = Paginator(data_list,pageSize)
          context = pageInator.page(pageIndex)
          for item in context:
              ref_data.append(item)
          # 返回分頁格式
          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實現完整表格分頁:

      通過使用layui框架完成的一個相對完整的表格分頁,可用于生產環境.

      !--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',  // 頁碼的參數名稱,默認:page
                        limitName: 'pageSize'   // 每頁數據量的參數名,默認:limit
                }
                ,response: {
                        statusName: 'code',     // 規定數據狀態的字段名稱,默認:code
                        statusCode: 0,          // 規定成功的狀態碼,默認:0
                        msgName: 'msg',         // 規定狀態信息的字段名稱,默認:msg
                        countName: 'DataCount', // 規定數據總數的字段名稱,默認:count
                        dataName: 'data'        // 規定數據列表的字段名稱,默認:data
                }
              ,cols: [[
                {type: 'checkbox', fixed: 'left'},
                {field:'id', title:'主機ID', width:100, sort: true},
                {field:'hostname', title:'主機名稱', width:120},
                {field:'hostaddr', title:'主機地址', width:120},
                {field:'hostmode', title:'主機組', width:120},
                {fixed: 'right', title:'操作', toolbar: '#barDemo', width:120}
              ]]
              ,page: {
                  layout: ['limit', 'count', 'prev', 'page', 'next', 'skip'],     // 自定義分頁布局
                  curr: 1,      // 設置默認起始頁1
                  groups: 10,   // 只顯示10個連續頁碼,就是說顯示10個可見頁其他的省略
                  first: false, // 不顯示首頁
                  last: false   // 不顯示尾頁
              },
              limit: 5,
              limits: [5,10,15,20,25]
            });
      // ------------------------------------------------------------------
      // 監聽行工具事件:也就是編輯與刪除的處理事件
            table.on('tool(test)', function(obj){
              var data = obj.data;
              if(obj.event === 'del'){
                layer.confirm('真的要刪除本行數據嗎 ?', {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:['修改數據','關閉'],anim: 4,
                    content:`div>
                                  主機序號: input type="text" style='display:inline-block' id="id">br>br>
                                  主機名稱: input type="text" style='display:inline-block' id="hostname">br>br>
                                  主機地址: input type="text" style='display:inline-block' id="hostaddr">br>br>
                                  主機屬組: input type="text" style='display:inline-block' id="hostmode">br>br>
                             /div>`,
                    yes:function (index,layero)
                    {
                        console.log("點擊yes觸發事件:" + 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) {
                              // 修改完成后,本地直接更新數據,這樣就無需刷新一次了
                                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);
              }
            });
      
              // 搜索后的重載,也就是找到數據以后直接更新
            var $ = layui.$, active = {
              reload: function(){
                var demoReload = $('#demoReload');
                //執行重載
                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("當前索引:{} 當前大小:{}".format(pageIndex,pageSize))
          print("所有記錄:{} 數據總條數:{}".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)
      ]

      自己實現分頁:

      轉載代碼,僅用于收藏。

      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
              # 數據總條數
              self.total_count = total_count
      
              # 每頁顯示10條數據
              self.per_page_count = per_page_count
      
              # 頁面上應該顯示的最大頁碼
              max_page_num, div = divmod(total_count, per_page_count)
              if div:
                  max_page_num += 1
              self.max_page_num = max_page_num
      
              # 頁面上默認顯示11個頁碼(當前頁在中間)
              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()
              # 包含當前列表頁面所有的搜/索條件
              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):
              # 如果總頁數 = 11
              if self.max_page_num = self.max_pager_count:
                  pager_start = 1
                  pager_end = self.max_page_num
              # 如果總頁數 > 11
              else:
                  # 如果當前頁 = 5
                  if self.current_page = self.half_max_pager_count:
                      pager_start = 1
                      pager_end = self.max_pager_count
                  else:
                      # 當前頁 + 5 > 總頁碼
                      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   #倒這數11個
                      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]}
              # 首頁
              self.params['page'] = 1
              first_page = '首頁' % (self.base_url,urlencode(self.params),)
              page_html_list.append(first_page)
              # 上一頁
              self.params["page"] = self.current_page - 1
              if self.params["page"] = 1:
                  pervious_page = '上一頁' % (self.base_url, urlencode(self.params))
              else:
                  pervious_page = '上一頁' % ( self.base_url, urlencode(self.params))
              page_html_list.append(pervious_page)
              # 中間頁碼
              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)
      
              # 下一頁
              self.params["page"] = self.current_page + 1
              if self.params["page"] > self.max_page_num:
                  self.params["page"] = self.current_page
                  next_page = '下一頁' % (self.base_url, urlencode(self.params))
              else:
                  next_page = '下一頁' % (self.base_url, urlencode(self.params))
              page_html_list.append(next_page)
      
              # 尾頁
              self.params['page'] = self.max_page_num
              last_page = '尾頁' % (self.base_url, urlencode(self.params),)
              page_html_list.append(last_page)
      
              return ''.join(page_html_list)

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

      以上就是Django Paginator分頁器的使用示例的詳細內容,更多關于Django Paginator分頁器的使用的資料請關注腳本之家其它相關文章!

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

      標簽:長春 泉州 岳陽 清遠 安慶 吉林 洛陽 怒江

      巨人網絡通訊聲明:本文標題《Django Paginator分頁器的使用示例》,本文關鍵詞  Django,Paginator,分頁,器,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
    • 相關文章
    • 下面列出與本文章《Django Paginator分頁器的使用示例》相關的同類信息!
    • 本頁收集關于Django Paginator分頁器的使用示例的相關信息資訊供網民參考!
    • 推薦文章
      成人a大片高清在线观看| 精品久久久久久综合网| 日韩在线观看视频黄| 国产成a人片在线观看视频| 国产伦精品一区三区视频| 精品在线免费播放| 欧美a级片视频| 成人a大片高清在线观看| 国产精品123| 日韩av东京社区男人的天堂| 久久99这里只有精品国产| 欧美另类videosbestsex高清| 一级毛片视频在线观看| 国产伦理精品| 久久国产精品自由自在| 日韩中文字幕一区| 成人在激情在线视频| 国产高清在线精品一区二区| 麻豆网站在线免费观看| 午夜激情视频在线播放| 一本高清在线| 久久福利影视| 精品国产三级a∨在线观看| 91麻豆国产| 日韩欧美一二三区| 国产不卡在线播放| 99久久精品国产国产毛片| 久久福利影视| 日韩中文字幕在线亚洲一区| 一级毛片视频播放| 成人免费观看男女羞羞视频| 韩国妈妈的朋友在线播放| a级毛片免费观看网站| 一级女性大黄生活片免费| 国产激情一区二区三区| 精品视频在线看| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 国产伦精品一区三区视频| 日韩专区一区| 日韩免费在线观看视频| 尤物视频网站在线| 国产高清在线精品一区二区| 毛片高清| 国产激情一区二区三区| 欧美a免费| 日本免费区| 国产成人女人在线视频观看| 国产激情一区二区三区| 天天做日日爱| 久久国产影院| 99热精品一区| 国产网站在线| 国产视频网站在线观看| 免费一级片在线观看| 91麻豆精品国产自产在线| 亚洲第一页乱| 欧美激情一区二区三区在线| 麻豆网站在线免费观看| 精品在线免费播放| 青青久热| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日韩一级精品视频在线观看| 成人a级高清视频在线观看| 国产亚洲精品aaa大片| 欧美国产日韩精品| 国产成人精品综合在线| 久草免费资源| 韩国妈妈的朋友在线播放| 精品视频免费看| 亚洲天堂免费观看| 国产亚洲精品aaa大片| 亚洲精品久久久中文字| 天天做日日爱| 久久国产精品自由自在| 日日日夜夜操| 国产综合成人观看在线| 精品国产一区二区三区久久久狼| 国产精品1024永久免费视频| 国产一区二区精品久久91| 日韩在线观看免费| 四虎影视久久久免费| 黄视频网站在线看| 99色视频在线观看| 精品国产一区二区三区免费| 成人免费观看网欧美片| 亚洲天堂免费观看| 天天色色色| 亚洲 欧美 91| 午夜久久网| 成人高清视频免费观看| 国产一区二区精品尤物| 欧美a级片视频| 国产伦理精品| 黄视频网站在线看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 精品久久久久久综合网| 国产一级生活片| 国产极品精频在线观看| a级毛片免费全部播放| 欧美激情中文字幕一区二区| 日韩专区亚洲综合久久| 九九九国产| 九九精品久久| a级毛片免费全部播放| 亚洲天堂一区二区三区四区| 99久久精品费精品国产一区二区| 免费的黄视频| 欧美国产日韩一区二区三区| 日日夜人人澡人人澡人人看免| 亚洲精品中文字幕久久久久久| 九九精品久久| 欧美一级视频免费观看| 亚洲第一视频在线播放| 中文字幕一区二区三区 精品| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 亚州视频一区二区| 国产亚洲男人的天堂在线观看| 久久国产影视免费精品| 国产福利免费视频| 成人免费福利片在线观看| 精品国产亚一区二区三区| 欧美18性精品| 国产一区二区精品在线观看| 你懂的在线观看视频| 精品久久久久久免费影院| 色综合久久久久综合体桃花网| 四虎影视久久| 精品国产亚一区二区三区| 九九九国产| 午夜在线亚洲男人午在线| 九九精品久久| 日韩专区在线播放| 黄视频网站在线观看| 日韩一级黄色片| 91麻豆精品国产片在线观看| 国产网站免费| 天天色色网| 精品国产一区二区三区精东影业| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 国产激情视频在线观看| 久久精品成人一区二区三区| 国产伦久视频免费观看视频| 国产高清在线精品一区a| 日日夜人人澡人人澡人人看免| 国产视频在线免费观看| 亚洲精品中文字幕久久久久久| 久久99爰这里有精品国产| 国产视频一区二区在线播放| 国产高清视频免费观看| 天天做人人爱夜夜爽2020毛片| 久久99爰这里有精品国产| 午夜激情视频在线观看| 国产精品1024永久免费视频 | 天堂网中文字幕| 国产91精品一区二区| 日本久久久久久久 97久久精品一区二区三区 狠狠色噜噜狠狠狠狠97 日日干综合 五月天婷婷在线观看高清 九色福利视频 | 一级女人毛片人一女人| 美女免费精品高清毛片在线视| 国产视频在线免费观看| 欧美激情一区二区三区在线播放| 黄色福利片| 精品视频一区二区三区免费| 99久久精品费精品国产一区二区| 国产激情视频在线观看| 91麻豆国产福利精品| 亚洲天堂一区二区三区四区| 天堂网中文字幕| 国产高清视频免费观看| 国产a网| 精品久久久久久中文字幕一区| 可以免费在线看黄的网站| 欧美爱色| 国产网站免费在线观看| 青青青草视频在线观看| 好男人天堂网 久久精品国产这里是免费 国产精品成人一区二区 男人天堂网2021 男人的天堂在线观看 丁香六月综合激情 | 日日夜人人澡人人澡人人看免| 欧美爱色| 国产国产人免费视频成69堂| 日韩av片免费播放| 国产极品白嫩美女在线观看看| 欧美日本免费| 97视频免费在线观看| 亚欧成人乱码一区二区| 国产网站免费在线观看| 精品久久久久久中文| 天天做人人爱夜夜爽2020毛片| 免费国产在线视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 欧美激情一区二区三区视频 | 四虎影视久久| 国产a免费观看| 国产麻豆精品视频| 成人免费网站久久久| 久久精品店| 色综合久久天天综合绕观看| 日韩女人做爰大片| 国产伦久视频免费观看视频| 欧美夜夜骑 青草视频在线观看完整版 久久精品99无色码中文字幕 欧美日韩一区二区在线观看视频 欧美中文字幕在线视频 www.99精品 香蕉视频久久 | 久久精品免视看国产成人2021| 精品视频免费在线|