Heim > Web-Frontend > js-Tutorial > Hauptteil

Ajax schreibt eine Paging-Abfrage (ohne die Seite zu aktualisieren)

韦小宝
Freigeben: 2018-01-01 18:21:42
Original
1675 Leute haben es durchsucht

In diesem Artikel werden hauptsächlich Beispiele für das Schreiben von Paging-Abfragen in Ajax vorgestellt (ohne Aktualisierung der Seite).

Anforderungen:

Um eine große Menge an Informationen in der Datenbank zu erhalten und auf der Seite anzuzeigen, Paging Es müssen Abfragen verwendet werden.

Wenn Sie kein Ajax, sondern andere Methoden verwenden, müssen Sie die Seite auf jeden Fall aktualisieren, und der Benutzergesundheitstest wird sehr schlecht sein Es ist am besten, Ajax zum Schreiben von Paging-Abfragen zu verwenden.

1. Suchen Sie zuerst eine Tabelle mit vielen Daten!

Eine einfache Tabelle

Code, Einführung des JQuery-Pakets:

<script src="jquery-1.11.2.min.js"></script> Schreiben Sie a Tabelle mit unseren Codenamen und Namen:

<table class="table table-striped">
 <thead>
 <tr>
 <td>代号</td>
 <td>名称</td>
 <td>操作</td>
 </tr>
 </thead>
 <tbody id="td">
 </tbody>
</table>
Nach dem Login kopieren

Das ist ganz einfach, kein Problem!

2. Legen Sie eine aktuelle Seite fest und definieren Sie eine Variable als 1 (erste Seite):

 var page = 1;
 //当前页,默认等于1
Nach dem Login kopieren

3. Schreiben wir die erste Methode: Sie müssen Ajax verwenden. Diese Methode wird hauptsächlich für Abfragen und Paging verwendet:

function load()
 {
 $.ajax({
  url: "jiazai.php",
// 显示所有的数据不用写data
  data:{page:page},
//当前页记得传过去
  type:"POST",
  dataType: "TEXT",
  success: function (data) {
  }
 });
 }
Nach dem Login kopieren

4. Schreiben Sie die Verarbeitungsseite für die Anzeige von Daten. Dabei ist zu berücksichtigen, wie viele Daten übersprungen werden sollen und wie viele Daten Sie anzeigen möchten:

<?php
include ("db.class.php");
$db = new db();
$page=$_POST["page"];
//去当前页page
$num = 3;
//每页显示几条
$tg = ($page-1)*3;//跳过几条
$sql = "select * from min limit {$tg},{$num}";
//limit:两个参数,第一个是跳过多少条,第二个是取多少条
echo $db->Query($sql);
Nach dem Login kopieren

Nach Abschluss des ersten Schritts werfen wir einen Blick auf das Bild:

Datenimplementierung anzeigen!

Okay, drei Daten pro Seite wurden zuerst implementiert (ich habe Bookstrap verwendet, um die Webseite zu verschönern, damit die Seite so aussieht, wie bereits erwähnt)

5. Seiteninformationen anzeigen Schreiben Sie eine Methode, um zuerst Ajax zu verwenden, um die Gesamtzahl der Seiten zu erhalten:

function loadfenye()
 {
 var s = "";
 //用于接收
 var xiao = 1;
// 最大页
 var da = 1;
// 最小页
 $.ajax({
 async:false,
//  做成同步
 url:"zys.php",
 dataType:"TEXT",
 success:function(data){
 da = data;
 //最大页数
  }
});
 }
Nach dem Login kopieren

Als nächstes fragen Sie die PHP-Seite ab die Gesamtzahl der Seiten:

<?php
//查询总页数
include ("db.class.php");
$db = new db();
$sql = "select count(*) from min";
$zts = $db->strquery($sql);
//总条数
echo ceil($zts/3);
//ceil向上取整
Nach dem Login kopieren

Okay, die Gesamtzahl der Seiten ist erhalten, kommen Sie zurück und beenden Sie die Paginierung:

//加载分页信息方法
 function loadfenye()
 {
  var s = "";
  //用于接收
  var xiao = 1;
//  最大页
  var da = 1;
//  最小页
  $.ajax({
 async:false,
//   做成同步
 url:"zys.php",
 dataType:"TEXT",
 success:function(data){
  da = data;
  //最大页数,查到的最大页数交个默认的最大页数
   }
});
//加载上一页
  s += "<li><a>«</a></li>";
//  加载分页列表
for(i=page-4;i<page+5;i++)
{
 //i代表列表的页数
 if(i>=xiao && i<=da)
 {
  s += " <li><a>"+i+"</a></li>"
 }
}
  //  加载下一页
  s += "<li><a>»</a></li>";
$("#fenye").html(s);
 }
Nach dem Login kopieren

Nachdem Sie dies geschrieben haben, schauen Sie sich das Bild an:

Die Seiteninformationen werden ebenfalls angezeigt

6. Komm schon, ändere die Hintergrundfarbe der standardmäßig ausgewählten Seite

Schau dir an, wie man die Hintergrundfarbe ändert:

Natürlich gibt es noch einen aktiven Stil, fügen wir ihn mit unserem Urteilsvermögen hinzu

if(i>=xiao && i<=da) {
  if (i == page) {
   s += " <li class=&#39;active&#39;><a>" + i + "</a></li>"
  }
  else {
   s += " <li><a>" + i + "</a></li>";
  }
Nach dem Login kopieren

Okay, werfen Sie einen Blick darauf:

Ja, kein Problem

7. Erstellen Sie ein Klickereignis auf die Seitenzahl, um zur Seitenzahl zu springen, die Daten anzuzeigen und die Liste zu aktualisieren 🎜>

Zuerst eine Klasse zur Zahlenliste hinzufügen

Dann schreiben Sie die Methode: s += " <li class=&#39;active list&#39;><a>" + i + "</a></li>"

//给列表加上点击事件
  $(".list").click(function(){
   //改变当前页数
   //把点击的页数,扔给page(当前页)
   page = $(this).text();
//   page获取了当前页,重新加载以下方法
   //调用load方法
   load();
   //把加载数据封装成一个方法
   loadfenye();
   //加载分页信息方法
  })
 }
Nach dem Login kopieren
Wenn ich auf die fünfte Seite klicke:

Kein Problem

8 Seite und der nächsten Seite Klickereignis, zuerst das Klickereignis auf der vorherigen Seite:

Zuerst Klasse zur Liste auf der vorherigen Seite hinzufügen, um das Schreiben von Ereignissen zu erleichtern:

Komm schon, klicke auf Ereignis auf der vorherigen Seite: s += "<li class=&#39;sy&#39;><a>«</a></li>";

$(".sy").click(function(){
   //改变当前页
   if(page>1)
   {
    //如果不是第一页
    page = parseInt(page) - 1;
   }
   //   page获取了当前页,重新加载以下方法
   //调用load方法
   load();
   //把加载数据封装成一个方法
   loadfenye();
   //加载分页信息方法
  })
Nach dem Login kopieren
Klicke auf Ereignis auf der nächsten Seite:

Das Gleiche wie oben: Klasse zur Liste hinzufügen, einfach zu schreibende Ereignisse:

s += "<li class=&#39;xy&#39;><a>»</a></li>"; Klickereignis für die nächste Seite:

//下一页点击事件
  $(".xy").click(function(){
//   alert(da);
   if(page<da)
   {
    //如果不是第一页
    page = parseInt(page) + 1;
   }
   //   page获取了当前页,重新加载以下方法
   //调用load方法
   load();
   //把加载数据封装成一个方法
   loadfenye();
   //加载分页信息方法
  })
Nach dem Login kopieren
OK, perfekte Implementierung der Ajax-Paging-Abfrage;

8. Fügen Sie eine bedingte Abfrage hinzu:

Fügen Sie ein Textfeld hinzu:

<p>
 <input type="text" id="name"/>
 <input type="button" id="chaxun" value="查询"/>
</p>
Nach dem Login kopieren

um das Klickereignis zu schreiben:

//给查询加点击事件
 $("#chaxun").click(function(){
  //重新加载
  //调用load方法
  load();
  //把加载数据封装成一个方法
  loadfenye();
  //加载分页信息方法
 })
Nach dem Login kopieren
Als nächstes müssen wir diese beiden Methoden ändern:

Ajax muss nur den Namen des Textfelds übergeben:


data:{page:page,name:name},
   type:"POST",
Nach dem Login kopieren

data:{name:name},
 type:"POST",
Nach dem Login kopieren
Legen Sie auf der Verarbeitungsseite eine Gleichheitsbedingung fest:

最后在sql语句后面调用就好啦

图:

页面不刷新的分页查询就欧克了;

源码:

显示页面:




 
 无标题文档
 
 <script src="jquery-1.11.2.min.js"></script>
 



显示数据

<p> <input type="text" id="name"/> <input type="button" id="chaxun" value="查询"/> </p>
代号 名称 操作

<script> var page = 1; //当前页,默认等于1 //调用load方法 load(); //把加载数据封装成一个方法 loadfenye(); //加载分页信息方法 //给查询加点击事件 $(&quot;#chaxun&quot;).click(function(){ //重新加载 //调用load方法 load(); //把加载数据封装成一个方法 loadfenye(); //加载分页信息方法 }) function loadfenye() { var s = ""; //用于接收 var name = $("#name").val(); var xiao = 1; // 最大页 var da = 1; // 最小页 $.ajax({ async:false, // 做成同步 url:"zys.php", data:{name:name}, type:&quot;POST&quot;, dataType:"TEXT", success:function(data){ da = data; //最大页数 } }); //加载上一页 s += &quot;&lt;li class=&amp;#39;sy&amp;#39;&gt;&lt;a&gt;«&lt;/a&gt;&lt;/li&gt;&quot;; // 加载分页列表 for(var i=page-4;i<page+5;i++) { //i代表列表的页数 if(i>=xiao && i<=da) { if (i == page) { s += &quot; &lt;li class=&amp;#39;active list&amp;#39;&gt;&lt;a&gt;&quot; + i + &quot;&lt;/a&gt;&lt;/li&gt;&quot; } else { s += " <li class=&#39;list&#39;><a>" + i + "</a></li>"; } } } // 加载下一页 s += "<li class=&#39;xy&#39;><a>»</a></li>"; $("#fenye").html(s); //给列表加上点击事件 $(".list").click(function(){ //改变当前页数 //把点击的页数,扔给page(当前页) page = $(this).text(); // page获取了当前页,重新加载以下方法 //调用load方法 load(); //把加载数据封装成一个方法 loadfenye(); //加载分页信息方法 }) //上一页点击事件 $(&quot;.sy&quot;).click(function(){ //改变当前页 if(page&gt;1) { //如果不是第一页 page = parseInt(page) - 1; } // page获取了当前页,重新加载以下方法 //调用load方法 load(); //把加载数据封装成一个方法 loadfenye(); //加载分页信息方法 }) //下一页点击事件 $(&quot;.xy&quot;).click(function(){ // alert(da); if(page&lt;da) { //如果不是第一页 page = parseInt(page) + 1; } // page获取了当前页,重新加载以下方法 //调用load方法 load(); //把加载数据封装成一个方法 loadfenye(); //加载分页信息方法 }) } function load() { var name = $("#name").val(); $.ajax({ url: "jiazai.php", // 显示所有的数据不用写data data:{page:page,name:name}, type:&quot;POST&quot;, dataType: "TEXT", success: function (data) { var str = ""; var hang = data.split("|"); //split拆分字符串 for (var i = 0; i < hang.length; i++) { //通过循环取到每一行;拆分出列; var lie = hang[i].split("-"); str = str + "<tr><td>" + lie[0] + "</td><td>" + lie[1] + "</td><td>" + "<button type=&#39;button&#39; class=&#39;btn btn-info sc&#39; ids=&#39;"+lie[0]+"&#39;>点击删除</button><button type=&#39;button&#39; class=&#39;btn btn-primary xq&#39; ids=&#39;"+lie[0]+"&#39;>查看详情</button>" + //ids里面存上主键值 "</td></tr>"; } $("#td").html(str); //找到td把html代码扔进去 addshanchu(); addxiangqing(); } }); } //给查看详情加事件 function addxiangqing() { $(".xq").click(function(){ $(&#39;#myModal&#39;).modal(&#39;show&#39;) //打开模态框 var ids = $(this).attr("ids"); $.ajax({ url:"xiangqing.php", data:{ids:ids}, dataType:"TEXT", type:"POST", success:function(data){ //拆分 var lie = data.split("^"); // var str = "<p>代号:"+lie[0]+"</p><p>名称:"+lie[1]"</p>"; //造字符串 var str = "<p>代号:"+lie[0]+"</p><p>名称:"+lie[1]+"</p>"; $("#nr").html(str); } }); //在模态框里面要显示的内容 }) } //把删除事件封装成方法: function addshanchu() { //给删除按钮加上事件 $(".sc").click(function () { var ids = $(this).attr("ids"); $.ajax({ url: "shanchu.php", data: {ids: ids}, dataType: "TEXT", type: "POST", success: function (d) { if (d.trim() == "ok") { alert("删除成功"); //调用加载数据的方法 load(); } else { alert("删除失败"); } } }); }) } </script>
Nach dem Login kopieren

查询总页数的页面:

<?php
//查询总页数
include ("db.class.php");
$db = new db();
$tj = " 1=1 ";
if(!empty($_POST["name"]))
{
 $name = $_POST["name"];
 $tj = " name like &#39;%{$name}%&#39; ";
}
$sql = "select count(*) from min WHERE {$tj} ";
$zts = $db->strquery($sql);
//总条数
echo ceil($zts/3);
//ceil向上取整
Nach dem Login kopieren

加载分页信息的页面:

<?php
include ("db.class.php");
$db = new db();
$page=$_POST["page"];
//去当前页page
$tj = " 1=1 ";
if(!empty($_POST["name"]))
{
 $name = $_POST["name"];
 $tj = " name like &#39;%{$name}%&#39; ";
}
$num = 3;
//每页显示几条
$tg = ($page-1)*3;//跳过几条
$sql = "select * from min where {$tj} limit {$tg},{$num}";
//limit:两个参数,第一个是跳过多少条,第二个是取多少条
$arr = $db->Query($sql);
//遍历
$str="";
foreach ($arr as $v)
{
 $str = $str.implode("-",$v)."|";
 //用-把$v拼起来,拼出来是1-红2-蓝,用|分割,拼出来是1-红|2-蓝|
}
$str = substr($str,0,strlen($str)-1);
//截取字符串:从第0个开始,截取它的长度-1
//strlen获取字符串长度
echo $str;
Nach dem Login kopieren

以上就是本篇文章的所有内容了,希望对大家学习有所帮助!

相关推荐:

json格式的Ajax提交示例代码

关于多个Ajax请求执行返回先后的问题示例探讨

AJax实现类似百度搜索栏的功能

Das obige ist der detaillierte Inhalt vonAjax schreibt eine Paging-Abfrage (ohne die Seite zu aktualisieren). Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage