Heim Web-Frontend js-Tutorial jQuery-Plug-in DataTables-Paging-Entwicklungstechnologie-Sharing

jQuery-Plug-in DataTables-Paging-Entwicklungstechnologie-Sharing

Dec 30, 2017 pm 02:41 PM
datatables jquery 开发技术

Dieser Artikel teilt Ihnen hauptsächlich die Erfahrungen mit der Entwicklung des jQuery-Plug-Ins DataTables. Ich hoffe, dass er allen helfen kann.

Zweck des Schreibens eines Blogs: Nicht aus Gründen der Popularität, nur um Notizen zu machen; egal, ob es langatmig ist, ich habe Angst, dass ich etwas verpasse und mich nicht erinnern kann es später.

Entwicklungsumgebung: Python 3.6.0, Anaconda 4.3.1, Django, JetBrains PyCharm 2017.1.5

Einfach organisiert nach dem Entwicklungsprozess meines Projekts.

1. Die erste Version, keine Paginierung.

Ich habe DataTables schon einmal verwendet (mehr Datagrid in easyui und der vorherige Server war PHP), daher dachte ich, dass es keinen großen Unterschied zwischen dem Frontend/Client und dem Server gibt, der derselbe ist Geben Sie trotzdem einen JSON-String gemäß dem Standardformat zurück (Djangos Code wird später aussortiert). Außerdem habe ich am Anfang nicht über das Paging von Tabellen nachgedacht, da ich nur drei Feldsortierungsanforderungen hatte (die Sortierung wurde auf der Serverseite durchgeführt und zurückgegeben).
DataTables-Basiscode:


//表格的HTML代码略过
$('#dtList').DataTable({
        "bPaginate": false, //翻页功能
        "bInfo": false,//页脚信息
        "ordering": false, //不排序
        "searching": false,  //搜索框,不显示
        "bLengthChange": false, //改变每页显示数据数量,不显示
        "iDisplayLength": 10,  //每页默认显示数量(不显示了,这个设置也起不了作用)
        "serverSide":true, //服务端
        "retrieve":false, //意思是如果已经初始化了,则继续使用之前的Datatables实例。

        "ajax": {
          "type": "POST",
          "url": "/manage/getlist/",
          "data":{'csrfmiddlewaretoken': '{{ csrf_token }}'}, //Django的token值
          "dataSrc": function (result) { //使用dataSrc属性来设置获取到的数据格式,其值是服务端拼好的key-value(数据字段名称-字段值)【服务端走了弯路,后续有时间再写文章说明】
            var json = JSON.parse(result).data;
            return json;
          }
        },
        "columns": [ //表格要显示的列定义(字段名称做了处理)
          { "data": "field0",
            "visible":false,
            "render": function ( data, type, full, meta ) {
              //return &#39;<input type="checkbox"/>&#39;;
              return data;
            }
          },
          { "data": "field1" },
          { "data": "field2" , //此列名要与服务端返回的JSON串中的值一致
            "render": function ( data, type, full, meta ) {
              return &#39;<p style="text-align:left">&#39;+data+&#39;</p>&#39;;
            }
          },
          //其余字段定义省略
          ]
        });
Nach dem Login kopieren

2. Paging-Funktion hinzufügen

Nachdem ich einige Tage lang das erste Programm geschrieben hatte, habe ich war bereit, die Paginierungsfunktion hinzuzufügen.
Anforderungen an das JSON-String-Format für DataTables:


{
  "draw": n, 
  "recordsTotal": n, //总记录数
  "recordsFiltered": n, //条件过滤后的记录数,与总记录数可能会不同
  "data": [{}] //获取到的记录集合
}
Nach dem Login kopieren

Nach den bisherigen Erfahrungen bei der Verarbeitung der Datagrid-Komponente in easyui ist die Gesamtzahl der Datensätze die Anzahl der Um gefilterte Datensätze usw. zu erhalten, müssen Sie nur die JSON-Zeichenfolge zusammenstellen und zurücksenden, und der Client kann Paging direkt implementieren.

Es stellt sich jedoch die Frage: Wie lässt sich der Draw-Wert steuern?

Nachdem ich die Informationen überprüft und den Browser-Header verfolgt habe, habe ich festgestellt, dass es sich bei der Zeichnung um einen Attributwert von DataTables selbst handelt. Es besteht keine Notwendigkeit, diese Daten an den Server zu übertragen Um diesen Wert zu ändern, geben Sie ihn einfach direkt in einer JSON-Zeichenfolge zurück. Ich habe es versucht, aber ich weiß nicht, wo das Problem liegt. Es scheint, dass das Paging nicht funktioniert, und ich habe immer das Gefühl, dass diese Steuerungsmethode etwas ermüdend ist.

Lassen Sie uns die Idee ändern und die Informationen erneut überprüfen, nämlich serverseitiges Paging (Anfordern entsprechender Daten bei Bedarf). Es gibt wirklich: django-datatables-view (Datentabellen für Django, https:/). /pypi.python.org/ pypi/django-datatables-view), befolgen Sie einfach die Installationsschritte. Auf diese Weise müssen Sie sich keine Gedanken über die Schreibweise der JSON-String-Werte machen. Diese Komponente ist fertig.

Verbesserter Frontend-Code:


$(&#39;#dtList&#39;).DataTable({
    "bPaginate": true, //翻页功能
    "bInfo": true,//页脚信息
    "ordering":true, //开启排序
    "searching": false, //搜索框,不显示
    "bLengthChange": true, //改变每页显示数据数量,不显示
    "aLengthMenu": [[5, 10, 25, 50, -1], [5, 10, 25, 50, "All"]], //每页显示记录菜单选项
    "iDisplayLength": 10, //每页默认显示数量
    "serverSide":true, //开启服务端请求模式
    &#39;pagingType&#39;: &#39;full_numbers&#39;,
    "retrieve":true,

    "ajax": { //这边就不需要dataSrc属性来处理值了
     "type": "GET",
     "url": "{% url &#39;scheme_list_json&#39; %}",
     "data":{
      &#39;sSearch&#39;:&#39;&#39;,
      &#39;csrfmiddlewaretoken&#39;: &#39;{{ csrf_token }}&#39;},
     },
    "columns": [ //表格要显示的列定义
     { "data": 0,
      "visible":false,
      "render": function ( data, type, full, meta ) {
       //return &#39;<input type="checkbox"/>&#39;;
       return data;
      }
     },
     { "data": 1
     "bSortable":false
     },
     { "data": 2,
      "bSortable":false, //此字段不排序
      "render": function ( data, type, full, meta ) {
       return &#39;<p style="text-align:left">&#39;+data+&#39;</p>&#39;;
      }
     },
     //其余字段定义省略
     ......
     ],
    "aaSorting": [ //指定排序的列(索引从0开始)及规则
     [ 8, "asc" ],
     [ 9, "asc" ],
     [ 10, "desc" ]
     ],
    "drawCallback": function( settings ) { //绘制表格时的回调函数
     $("th").removeClass("sorting_asc"); //删除排序图标,升序样式
     $("th").removeClass("sorting_desc");//降序样式 
   });
Nach dem Login kopieren

Die Sortierung ist erfolgreich, es tritt jedoch ein Problem auf: Nachdem die Sortierfunktion aktiviert wurde , in der Kopfzeile Es wird ein Sortiersymbol geben, aber wir brauchen es nicht (nur Sortieren, kein Klicken), also fügen Sie einfach die Rückruffunktion drawCallback in den obigen Code ein und entfernen Sie ihren Stil.
PS:
Es gibt eine Gefahr: Die Anzahl der Spalten im Rückgabefeld des Servers und im Sortierfeld muss eins zu eins übereinstimmen, und die Spaltendefinitionen des Front-End-DataTables-Anzeigefelds müssen andernfalls ebenfalls in dieser Reihenfolge sein Die Front-End-Sortierung wird durcheinander gebracht, wie zum Beispiel:


 # 需要显示的字段
 columns = [&#39;jyjhbid&#39;, &#39;tzbd&#39;, &#39;clsc&#39;, &#39;clzt&#39;, &#39;jlscrq&#39;, &#39;jlxgrq&#39;, &#39;clcz&#39;] 

 # 排序
 order_columns = [&#39;jyjhbid&#39;, &#39;tzbd&#39;, &#39;clsc&#39;, &#39;clzt&#39;, &#39;jlscrq&#39;, &#39;jlxgrq&#39;, &#39;clcz&#39;]
Nach dem Login kopieren

Ich bin neu bei django-datatables-view und dachte, dass die beiden Sammlungswerte ​​​​​kann unterschiedlich sein, also. . . . Weitere Meilen gelaufen.

Verwandte Empfehlungen:

Was tun, wenn die Header von jQuery Datatables nicht ausgerichtet sind?

Was tun, wenn die Header von Datatables nicht ausgerichtet sind nicht ausgerichtet

Einführung in die Datentabellenattribute des JQuery-Plug-Ins und ausführliche Erläuterung zum Erstellen von Paging- und Sortierbeispielen

Das obige ist der detaillierte Inhalt vonjQuery-Plug-in DataTables-Paging-Entwicklungstechnologie-Sharing. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Ausführliche Erläuterung der jQuery-Referenzmethoden: Kurzanleitung Ausführliche Erläuterung der jQuery-Referenzmethoden: Kurzanleitung Feb 27, 2024 pm 06:45 PM

Detaillierte Erläuterung der jQuery-Referenzmethode: Kurzanleitung jQuery ist eine beliebte JavaScript-Bibliothek, die häufig in der Website-Entwicklung verwendet wird. Sie vereinfacht die JavaScript-Programmierung und bietet Entwicklern umfangreiche Funktionen und Features. In diesem Artikel wird die Referenzmethode von jQuery ausführlich vorgestellt und spezifische Codebeispiele bereitgestellt, um den Lesern einen schnellen Einstieg zu erleichtern. Einführung in jQuery Zuerst müssen wir die jQuery-Bibliothek in die HTML-Datei einführen. Es kann über einen CDN-Link eingeführt oder heruntergeladen werden

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Wie entferne ich das Höhenattribut eines Elements mit jQuery? Feb 28, 2024 am 08:39 AM

Wie entferne ich das Höhenattribut eines Elements mit jQuery? Bei der Front-End-Entwicklung müssen wir häufig die Höhenattribute von Elementen manipulieren. Manchmal müssen wir möglicherweise die Höhe eines Elements dynamisch ändern, und manchmal müssen wir das Höhenattribut eines Elements entfernen. In diesem Artikel wird erläutert, wie Sie mit jQuery das Höhenattribut eines Elements entfernen, und es werden spezifische Codebeispiele bereitgestellt. Bevor wir jQuery zum Betreiben des Höhenattributs verwenden, müssen wir zunächst das Höhenattribut in CSS verstehen. Das Höhenattribut wird verwendet, um die Höhe eines Elements festzulegen

Wie verwende ich die PUT-Anfragemethode in jQuery? Wie verwende ich die PUT-Anfragemethode in jQuery? Feb 28, 2024 pm 03:12 PM

Wie verwende ich die PUT-Anfragemethode in jQuery? In jQuery ähnelt die Methode zum Senden einer PUT-Anfrage dem Senden anderer Arten von Anfragen, Sie müssen jedoch auf einige Details und Parametereinstellungen achten. PUT-Anfragen werden normalerweise zum Aktualisieren von Ressourcen verwendet, beispielsweise zum Aktualisieren von Daten in einer Datenbank oder zum Aktualisieren von Dateien auf dem Server. Das Folgende ist ein spezifisches Codebeispiel, das die PUT-Anforderungsmethode in jQuery verwendet. Stellen Sie zunächst sicher, dass Sie die jQuery-Bibliotheksdatei einschließen. Anschließend können Sie eine PUT-Anfrage senden über: $.ajax({u

jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite Feb 28, 2024 pm 09:06 PM

Titel: jQuery-Tipps: Ändern Sie schnell den Text aller Tags auf der Seite. In der Webentwicklung müssen wir häufig Elemente auf der Seite ändern und bedienen. Wenn Sie jQuery verwenden, müssen Sie manchmal den Textinhalt aller a-Tags auf der Seite gleichzeitig ändern, was Zeit und Energie sparen kann. Im Folgenden wird erläutert, wie Sie mit jQuery den Text aller Tags auf der Seite schnell ändern können, und es werden spezifische Codebeispiele angegeben. Zuerst müssen wir die jQuery-Bibliotheksdatei einführen und sicherstellen, dass der folgende Code in die Seite eingefügt wird: &lt

Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Feb 28, 2024 pm 05:42 PM

Titel: Verwenden Sie jQuery, um den Textinhalt aller Tags zu ändern. jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur Verarbeitung von DOM-Operationen verwendet wird. Bei der Webentwicklung müssen wir häufig den Textinhalt des Link-Tags (eines Tags) auf der Seite ändern. In diesem Artikel wird erläutert, wie Sie mit jQuery dieses Ziel erreichen, und es werden spezifische Codebeispiele bereitgestellt. Zuerst müssen wir die jQuery-Bibliothek in die Seite einführen. Fügen Sie den folgenden Code in die HTML-Datei ein:

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Feb 29, 2024 am 09:03 AM

Wie kann man feststellen, ob ein jQuery-Element ein bestimmtes Attribut hat? Wenn Sie jQuery zum Betreiben von DOM-Elementen verwenden, stoßen Sie häufig auf Situationen, in denen Sie feststellen müssen, ob ein Element ein bestimmtes Attribut hat. In diesem Fall können wir diese Funktion einfach mit Hilfe der von jQuery bereitgestellten Methoden implementieren. Im Folgenden werden zwei häufig verwendete Methoden vorgestellt, um festzustellen, ob ein jQuery-Element über bestimmte Attribute verfügt, und um spezifische Codebeispiele anzuhängen. Methode 1: Verwenden Sie die Methode attr() und den Operator typeof //, um zu bestimmen, ob das Element ein bestimmtes Attribut hat

Verstehen Sie die Rolle und Anwendungsszenarien von eq in jQuery Verstehen Sie die Rolle und Anwendungsszenarien von eq in jQuery Feb 28, 2024 pm 01:15 PM

jQuery ist eine beliebte JavaScript-Bibliothek, die häufig zur DOM-Manipulation und Ereignisbehandlung in Webseiten verwendet wird. In jQuery wird die Methode eq() verwendet, um Elemente an einer bestimmten Indexposition auszuwählen. Die spezifischen Verwendungs- und Anwendungsszenarien sind wie folgt. In jQuery wählt die Methode eq() das Element an einer angegebenen Indexposition aus. Indexpositionen beginnen bei 0 zu zählen, d. h. der Index des ersten Elements ist 0, der Index des zweiten Elements ist 1 und so weiter. Die Syntax der eq()-Methode lautet wie folgt: $("s

Zusammenfassung häufig verwendeter Dateioperationsfunktionen in PHP Zusammenfassung häufig verwendeter Dateioperationsfunktionen in PHP Apr 03, 2024 pm 02:52 PM

Parameter 1:basename()2:copy()3:dirname()4:disk_free_space()5:disk_total_space()6:file_exists()7:file_get_contents()8:file_put_contents()9:filesize()10:filetype( )11:glob()12:is_dir()13:is_writable()14:mkdir()15:move_uploaded_file()16:parse_ini_file()17:

See all articles