欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

使用ajax實(shí)現(xiàn)分頁技術(shù)

 更新時(shí)間:2017年02月09日 10:56:19   作者:前端dog  
這篇文章主要為大家詳細(xì)介紹了如何使用ajax實(shí)現(xiàn)分頁技術(shù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

ajax分頁效果圖如下:

首先,先看 HTML 代碼和 CSS 代碼,我們需要一個(gè) table 和一個(gè) footer:

<div id="global">
<div id="table">
 <table>
 <col width="19%">
 <col width="19%">
 <col width="19%">
 <col width="19%">
 <col width="24%">
 <tr>
 <th>日期</th>
 <th>時(shí)間</th>
 <th>事件</th>
 <th>報(bào)警畫面</th>
 <th>事件備注</th>
 </tr>
 </table>
 </div>
 <div id="footer">
 <span id="summary"></span>
 <ul id="pagination">
 <li id="01">首頁</li>
 <li id="02">上一頁</li>
 <li id="03">下一頁</li>
 <li id="04">最后一頁</li>
 </ul>
 <div id="select">
 <span>跳轉(zhuǎn)到 </span>
 <input type="text" name="page_num">
 <span> 頁 </span>
 <input type="button" name="go_btn" value="跳轉(zhuǎn)">
 </div>
 </div>
</div>

下面是 css 代碼:

#global{
 position: relative;
}
#table{
 position: absolute;
 top:19%;
 left:1.6%;
 width: 55%;
}
#table textarea{
 width: 10vw;
 height: 10vh;
 background-color: transparent;
 color: #fff;
 border-width: 0;
 text-align: center;
}
table, th, td {
 border: 0.2px solid rgba(60,166,206,0.2);
 border-collapse: collapse;
 color:rgba(60,166,206,1); 
}
th, td {
 padding: 3px;
 text-align: center;
 font-size: 1.6vmin;
}
td{
 background: rgba(2,29,54,1);
}
th{
 background: rgba(20,29,54,1);
 padding: 1.8% 0;
 color: rgba(255,255,255,0.8);
}
#footer{
 position: absolute;
 bottom:5vh;
 left:7vw;
 text-align: center;
 color: rgba(60,166,206,1);
}
#pagination{
 display: inline-block;
}
#pagination li{
 display: inline;
}
#select{
 display: inline-block;
 margin-left: 40px;
}
#select input[type="text"]{
 width: 30px;
 height: 20px;
 background-color: #000;
 border-width: 1px;
}
#select input[type="button"]{
 width: 40px;
 height: 23px;
 background: #000;
 border:none;
}
ul li{
 cursor: pointer;
}

初始化開始日期,結(jié)束日期,請求的頁數(shù),請求的每頁數(shù)量,總共有多少頁數(shù)據(jù),并通過 ajax 將這些數(shù)據(jù)傳給后臺提供的 API 數(shù)據(jù)接口,進(jìn)而從數(shù)據(jù)庫中獲取到數(shù)據(jù),然后可以在前端展示:

var start_date = "2017-01-01", end_date = "2017-01-08";
var pageNo = 1;
var pageSize = 4;
var pages = 0;

如何獲取表格的數(shù)據(jù)并將其 append 到前端?如何獲取分頁的數(shù)據(jù)并將其 append 到前端?使用下面我們定義的函數(shù):

loadData(pageNo, pageSize);

接下來看這個(gè)函數(shù)如何跟 API 數(shù)據(jù)接口溝通:

function loadData(pageNo, pageSize){
 $(".detail").remove(); //每次重新從 API 數(shù)據(jù)接口獲取數(shù)據(jù)都要先清除原先表格 `<tr>` 的內(nèi)容
 $.ajax({
 url: "/history_alarm",
 type: "POST",
 data: JSON.stringify({date:date, page_num:pageNo, page_size:pageSize}),
 success:function(result){
 var results = JSON.parse(result);
 var list = results.alarm;
 var totalCount = results.alarm_count;
 pages = results.page_count;
 if(list.length != 0){
  for(var i=0; i<list.length; i++){
  var alarm_id = list[i].alarm_id;
  var alarm_pic = list[i].alarm_pic;
  var date = list[i].date;
  var event = list[i].event;
  var time = list[i].time;
  var remark = list[i].remark;
  appendData(alarm_id, alarm_pic, date, event, time, remark);
  addEvent(alarm_id);
  }
  $("#table").show();
  $("#footer").show();
  displayFooter(totalCount, pages, pageNo);
 } else{
  $("#table").hide();
  $("#footer").hide();
 }
 },
 error:function(){
 //error handle function
 }
 });
 }

在 loadData 這個(gè)函數(shù)中我們還定義了另外3個(gè)函數(shù),接下來我們先來看 appendData:

//注意到我們將 `alarm_id` 作為 `<textarea>` 'class` 的值,也作為提交按鈕 `id` 的值,這是因?yàn)槲覀円ㄟ^ ajax 將用戶輸入到某一個(gè) `<textarea>` 的值作為參數(shù)傳給后臺 API 接口,由其寫入數(shù)據(jù)庫。
function appendData(alarm_id, alarm_pic, date, event, time, remark){
 var text = '<tr class="detail"><td>'+date+'</td><td>'+time+'</td<td>'+event+'</td>'+
  '<td><img class="img01" src=data:image/jpeg;base64,' + alarm_pic + '</td>'+
  '<td class="modity_btn"><textarea cols="5" rows="3" 
  class='+alarm_id+'>'+remark+'</textarea>'+'<img id='+alarm_id+' src="{{ 
  static_url("slice/modify.png") }}"></td></tr>';;

 $("#table table").append(text);
 }

//該函數(shù)定義了如何通過 ajax 將用戶輸入到某一個(gè) `<textarea>` 的值作為參數(shù)傳給后臺 API 接口,并寫入數(shù)據(jù)庫
function addEvent(alarm_id){
 $("#"+alarm_id).click(function(){
 var remark = $("."+alarm_id).val();
 if(remark != ""){
 $.ajax({
  url:"/history_alarm",
  type:"POST",
  data:JSON.stringify({alarm_id:alarm_id, note:remark}),
  success:function(result){
  var results = JSON.parse(result);
  if(results.status == "ok"){
  console.log('ok');
  }
  }
 })
 }
 })
 }
function displayFooter(totalCount, pages, pageNo){
 var newText = '共' + totalCount + '條,' + '第' + pageNo + '頁,' + '共' + pages + '頁';
 $("#summary").text(newText);
 }

獲取數(shù)據(jù)的函數(shù)寫好了,接下來就要點(diǎn)擊分頁的“首頁、上一頁、下一頁、最后一頁、跳轉(zhuǎn)”時(shí)候所對應(yīng)的事件了。思路是這樣的:用戶點(diǎn)擊分頁的每一個(gè)項(xiàng)目,都要重新判斷 pageNo,然后將 pageNo 作為參數(shù),再次調(diào)用獲取數(shù)據(jù)的 API 接口:

$("input[name='page_num']").keydown(function(e){ if(e.keyCode == 13){ $("input[name='go_btn']").click(); } });

$("input[name='go_btn']").click(function(){
 var goPage = $("input[name='page_num']").val();
 if(goPage >= 1 && goPage <=pages && goPage != pageNo){
  pageNo = goPage;
  loadData(pageNo, pageSize);
 } else{
  return false;
 }
});

$("#01").click(function(){
 pageNo = 1;
 loadData(pageNo, pageSize);
});

$("#04").click(function(){
 pageNo = pages;
 loadData(pageNo, pageSize);
});

$("#02").click(function(){
 if(pageNo == 1){
  return false;
 } else{
  pageNo--;
  loadData(pageNo, pageSize);
 }
});

$("#03").click(function(){
 if(pageNo == pages){
  return false;
 } else{
  pageNo++;
  loadData(pageNo, pageSize);
 }
});

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • jQuery通過Ajax向PHP服務(wù)端發(fā)送請求并返回JSON數(shù)據(jù)

    jQuery通過Ajax向PHP服務(wù)端發(fā)送請求并返回JSON數(shù)據(jù)

    這篇文章主要介紹了jQuery通過Ajax向PHP服務(wù)端發(fā)送請求并返回JSON數(shù)據(jù),設(shè)計(jì)到的知識點(diǎn)有jquery、ajax、php、json,感興趣的朋友一起學(xué)習(xí)下jquery ajax 返回json
    2015-10-10
  • ajax設(shè)置header指南教程

    ajax設(shè)置header指南教程

    Ajax 是一個(gè)令人誤導(dǎo)的名稱,Ajax 應(yīng)用程序可能使用 XML 來傳輸數(shù)據(jù),但將數(shù)據(jù)作為純文本或 JSON 文本傳輸也同樣常見,本文給大家介紹ajax設(shè)置header指南教程,感興趣的朋友一起看看吧
    2023-10-10
  • JSP+Ajax 添加、刪除多選框

    JSP+Ajax 添加、刪除多選框

    這篇文章主要介紹了JSP+Ajax 添加、刪除多選框
    2006-10-10
  • 深入淺析Nginx實(shí)現(xiàn)AJAX跨域請求問題

    深入淺析Nginx實(shí)現(xiàn)AJAX跨域請求問題

    AJAX從一個(gè)域請求另一個(gè)域會有跨域的問題。那么如何在nginx上實(shí)現(xiàn)ajax跨域請求呢?此問題難住很多朋友,下面小編給大家?guī)砹薔ginx實(shí)現(xiàn)AJAX跨域請求問題的相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧
    2016-06-06
  • Baidu Musicbox 用到的ajax代碼

    Baidu Musicbox 用到的ajax代碼

    Baidu Musicbox 用到的ajax代碼...
    2007-09-09
  • 用ajax實(shí)現(xiàn)預(yù)覽鏈接可以看到鏈接的內(nèi)容

    用ajax實(shí)現(xiàn)預(yù)覽鏈接可以看到鏈接的內(nèi)容

    用CSS設(shè)置預(yù)覽彈出窗口的樣式、用JavaScript進(jìn)行服務(wù)器請求并且顯示彈出窗口,需要的朋友可以參考下
    2014-08-08
  • AJAX頁面狀態(tài)保持思路詳解

    AJAX頁面狀態(tài)保持思路詳解

    AJAX流行的時(shí)候,很多信息為AJAX異步請求,比如:點(diǎn)擊、翻頁等。通常這種情況你一刷新瀏覽器,當(dāng)前頁面就會重置到初始狀態(tài)。更不用說把看到的信息url發(fā)給好友了。下面給大家分享實(shí)現(xiàn)思路,一起看看吧
    2017-03-03
  • AJAX實(shí)現(xiàn)JSON與XML數(shù)據(jù)交換方法詳解

    AJAX實(shí)現(xiàn)JSON與XML數(shù)據(jù)交換方法詳解

    這篇文章主要介紹了AJAX實(shí)現(xiàn)JSON與XML數(shù)據(jù)交換方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2023-01-01
  • ajax同步異步簡單實(shí)現(xiàn)

    ajax同步異步簡單實(shí)現(xiàn)

    本文為大家介紹下ajax同步異步的簡單實(shí)現(xiàn),感興趣的朋友可以參考下
    2014-01-01
  • 用iframe設(shè)置代理解決ajax跨域請求問題

    用iframe設(shè)置代理解決ajax跨域請求問題

    面對ajax跨域請求的問題,想用代理的方式來解決這個(gè)跨域問題。在服務(wù)器端創(chuàng)建一個(gè)靜態(tài)的代理頁面,在客戶端用iframe調(diào)用這個(gè)代理
    2013-11-11

最新評論