js分頁(yè)之前端代碼實(shí)現(xiàn)和請(qǐng)求處理
分頁(yè)之js前端實(shí)現(xiàn)和請(qǐng)求處理代碼,供大家參考,具體內(nèi)容如下
index.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link rel="stylesheet" href="css/public.css" charset='utf-8'> </head> <body> <div class='box'> <h2> <span>編號(hào)</span> <span>姓名</span> <span>性別</span> <span>分?jǐn)?shù)</span> </h2> <ul class='con' id='content'> <li> <span>1</span> <span>xxx</span> <span>男</span> <span>90</span> </li> </ul> <div class='page' id='page'> <span>FIRST</span> <span>PREV</span> <ul class='pageNum' id='pageNum'> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> </ul> <span>NEXT</span> <span>LAST</span> <input type="text" id='numInp' value='1'/> </div> </div> <script src='js/ajax.js'></script> <script> var pageModule = (function(){ //獲取需要操作的DOM元素 var content = document.getElementById('content'), page = document.getElementById('page'), pageNum = document.getElementById('pageNum'), numInp = document.getElementById('numInp'); //設(shè)定當(dāng)前也和總頁(yè)數(shù)及本次請(qǐng)求的數(shù)據(jù) var n = 1,total = 0,data = null; //實(shí)現(xiàn)頁(yè)面數(shù)據(jù)綁定及其他數(shù)據(jù)的綁定 function bindHTML(){ //content bind var str = ''; for(var i = 0;i<data.length;i++){ var curData = data[i]; str+='<li studentId="'+curData["id"]+'">'; str+='<span>'+curData["id"]+'</span>'; str+='<span>'+curData["name"]+'</span>'; str+='<span>'+(curData["sex"]==1 ? "女" : "男")+'</span>'; str+='<span>'+curData["score"]+'</span>'; str+='</li>'; } content.innerHTML = str; //page bind str = ''; for(i = 1;i<=total;i++){ if(i===n){ str+='<li class="bg">'+i+'</li>'; continue; } str+='<li>'+i+'</li>'; } pageNum.innerHTML = str; //numInp bind numInp.value = n; } //事件委托實(shí)現(xiàn)分頁(yè)區(qū)域的按鈕操作 給文本框enter鍵綁定操作 function bindEvent(){ page.onclick = function(e){ e = e || window.event; var tar = e.target || e.srcElement tarTag = tar.tagName.toUpperCase(), tarInn = tar.innerHTML; if(tarTag==="SPAN"){ if(tarInn==="FIRST"){ if(n===1){ return; } n = 1; } if(tarInn==="LAST"){ if(n === total){ return; } n = total; } if(tarInn==="PREV"){ if(n === 1){ return; } n--; } if(tarInn==="NEXT"){ if(n === total){ return; } n++; } } if(tarTag==="LI"){ if(n === parseFloat(tarInn)){ return; } n = parseFloat(tarInn); } //input if(tarTag==="INPUT"){ return; } //重新發(fā)送請(qǐng)求 sendAJAX() } numInp.onkeyup = function(e){ e = e || window.event; if(e.keyCode===13){//enter鍵 var val = parseFloat(this.value.replace(/^ +| +$/,'')); if(isNaN(val)){ this.value = n; return; } val = Math.round(val) if(val<1){ n = 1; }else if(val>total){ n = total; }else{ n = val; } sendAJAX(); } } } //content區(qū)域的LI跳轉(zhuǎn)事件 function bindLink(){ var oLis = content.getElementsByTagName('li'); for(var i = 0;i<oLis.length;i++){ oLis[i].onclick = function(){ // window.location.href = "detail.html"; //在跳轉(zhuǎn)的時(shí)候還需要把當(dāng)前點(diǎn)擊學(xué)員得ID傳到詳情頁(yè)面 window.open("detail.html?id="+this.getAttribute('studentId')); } } } function sendAJAX(){ ajax({ url:"/getList?n="+n, success:function(jsonData){ if(jsonData && jsonData.code===0){ total = jsonData["total"]; data = jsonData['data']; bindHTML(); bindLink(); } } }) } //模塊入口 function init(){ sendAJAX(); bindEvent(); } return { init:init } })() pageModule.init(); </script> </body> </html>
detail.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <link rel="stylesheet" href="css/public.css" charset='utf-8'> </head> <body> <ul class='box2' id='box2'> <li> <span>編號(hào)</span> <span>4</span> </li> <li> <span>姓名</span> <span>xxx</span> </li> <li> <span>性別</span> <span>男</span> </li> <li> <span>分?jǐn)?shù)</span> <span>99</span> </li> </ul> <script src='js/ajax.js'></script> <script> String.prototype.queryURLParameter = function(){ //PARAMETER var obj = {}, reg = /([^?=&#]+)=([^?=&#]+)/g; this.replace(reg,function(){ var key = arguments[1], value = arguments[2]; obj[key] = value; }); //->HASH // reg = /#([^?=&#]+)/; // if (reg.test(this)) { // obj['hash'] = reg.exec(this)[1]; // } return obj; } var detailModuel = (function(){ var data = null,urlId = window.location.href.queryURLParameter().id,oBox = document.getElementById('box2'); function bindHTML(){ var str = ""; str+="<li><span>編號(hào)</span><span>"+data["id"]+"</span></li>"; str+="<li><span>編號(hào)</span><span>"+data["name"]+"</span></li>"; str+="<li><span>編號(hào)</span><span>"+(data["sex"]==1 ? "男" : "女")+"</span></li>"; str+="<li><span>編號(hào)</span><span>"+data["score"]+"</span></li>"; oBox.innerHTML = str; } function init(){ ajax({ url:"/getInfo?id="+urlId, success:function(jsonData){ if(jsonData && jsonData.code===0){ data = jsonData["data"]; bindHTML(); } } }) } return { init:init } })() detailModuel.init(); </script> </body> </html>
最終效果圖:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript 分號(hào)總結(jié)及詳細(xì)介紹
這篇文章主要介紹了javascript 分號(hào)總結(jié)及詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-09-09淺析創(chuàng)建javascript對(duì)象的方法
下面小編就為大家?guī)?lái)一篇淺析創(chuàng)建javascript對(duì)象的方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-05-05javascript ajax 仿百度分頁(yè)函數(shù)
百度分頁(yè)想必大家都知道吧,瀏覽網(wǎng)頁(yè)的朋友都應(yīng)該知道,下面有個(gè)小例子使用到了js、ajax等來(lái)模仿百度的分頁(yè),感興趣的朋友可以參考下2013-10-10一文教你實(shí)現(xiàn)JavaScript防抖優(yōu)化代碼
在我們前端編程中,假如我們要給后端發(fā)送請(qǐng)求,萬(wàn)一手抖多點(diǎn)了幾次,多發(fā)送了幾遍怎么辦,那就得用防抖處理,下面小編就來(lái)教大家如何實(shí)現(xiàn)防抖吧2023-11-11使用3D引擎threeJS實(shí)現(xiàn)星空粒子移動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了使用3D引擎threeJS實(shí)現(xiàn)星空粒子移動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-11-11前端防抖(Debounce)和節(jié)流(Throttle)的概念、區(qū)別、應(yīng)用場(chǎng)景及實(shí)現(xiàn)方法
這篇文章主要介紹了前端開(kāi)發(fā)中常用的防抖(Debounce)和節(jié)流(Throttle)技術(shù)的相關(guān)資料,文章還提供了JavaScript的防抖和節(jié)流實(shí)現(xiàn)示例,并展示了如何在實(shí)際項(xiàng)目中結(jié)合使用這兩種技術(shù)以達(dá)到最佳效果,需要的朋友可以參考下2025-01-01