由于查询返回的数据量很大,超过10w条数据,因此需要对页面查询功能进行优化。放弃原有程序中使用DataGrid的做法,自己编写分页显示模块。
首先在页面上添加几个DIV:
<div id="div_trackpoint" style=" border:solid 1px gray; height:230px; width:99%; overflow-y:auto;">用于显示查询回的数据</div>
<div id="div_trackpages" style=" height:15px; width:99%; font-size:8pt; word-break:break-all; word-wrap: break-word;">用于显示分页的页码</div><br />
<div id="div_trackpagetab" style=" height:15px; width:99%; font-size:8pt; text-align:center;">用于显示前一页、后一页、...、首页、尾页等控制按钮</div>
<div id="div_trackpage_status" style=" height:20px; width:99%; font-size:8pt; text-align:center;">用于显示当前页的页码</div>
实现客户端分页函数:
var CurPage=0; //当前页
var TotalPage=0; //总页数
var PageTab=7; //每组显示页数
var CurTab=0; //当前分组
我的程序是设置每页显示50条数据,每组显示7页,这些可以按需求调整。
TurnTab函数用于切换分组,根据传入的val来计算显示哪一组页面。val=1表示切换到下一组,val=-1表示切换到上一组,0表示切换到第一组,-2表示切换到最后一组。用户通过单击页面上的 ... 符号来切换分组。
function TurnTab(val)
{
var nPage = 0;
if (val == 1) {
CurTab++;
nPage = (CurTab - 1) * PageTab + 1;
}
else if (val == -1) {
CurTab--;
nPage = (CurTab - 1) * PageTab + 1;
}
else if (val == 0) {
CurTab = 1;
nPage = 1;
}
else if (val == -2) {
CurTab = Math.floor(TotalPage / PageTab) + 1;
nPage = (CurTab - 1) * PageTab + 1;
}
var carinfo = document.getElementById("div_trackpages");
var tabinfo = document.getElementById("div_trackpagetab");
var strInner = "";
strInner += "<a href=\"javascript:TurnPage(1)\">首页</a> ";
strInner += "<a href=\"javascript:PreviousPage()\">前一页</a> ";
strInner += "总共" + TotalPage + "页 ";
strInner += "<a href=\"javascript:NextPage()\">下一页</a> ";
strInner += "<a href=\"javascript:TurnPage(" + TotalPage + ")\">尾页</a> ";
tabinfo.innerHTML = strInner;
strInner = "";
if (CurTab > 1) strInner += "<a href=\"javascript:TurnTab(-1)\">...</a> ";
for ( ; nPage<=CurTab*PageTab; nPage++) {
if (nPage <= TotalPage) {
strInner += "<a href=\"javascript:TurnPage("+ nPage + ")\">"+nPage+"</a> "
}
}
if (nPage < TotalPage) strInner += "<a href=\"javascript:TurnTab(1)\">...</a> ";
carinfo.innerHTML = strInner;
}
TurnPage函数用于切换分页,val表示要切换到的页数,根据要显示的页数生成查询范围,如查询前50条记录,从51到100的记录,从101到150的记录。。。
cscCustomAnalyst是一个异步调用函数,函数实现的代码将在下面贴出。"Method","SID", "TIME1", "TIME2", "ROW1", "ROW2"都是执行查询所需的参数,Method是用来判断要执行什么查询,"ROW1", "ROW2"表示要查询的记录范围,其他的参数就根据实际需要进行调整。ShowCarTrack(val)是一个对查询结果进行处理的函数,异步调用完成后得到的结果就将在这个函数中分析处理并且显示。这部分代码按照具体实现编写,我这里就不列出。
function TurnPage(val)
{
if (Number(val) != CurPage) {
CurPage = Number(val);
var row1 = String((CurPage - 1) * 50 + 1);
var row2 = String(CurPage * 50);
var trackinfo = document.getElementById("div_trackpoint");
trackinfo.innerHTML = " 获取数据中,请稍等...";
_cscCustomAnalyst(["Method", "SID", "TIME1", "TIME2", "ROW1", "ROW2"],
["GetCarTrack",, "80100117", t1, t2, row1, row2],
ShowCarTrack,onQueryError);
if (CurPage == 1) TurnTab(0);
if (CurPage == TotalPage) TurnTab(-2);
var statusinfo = document.getElementById("div_trackpage_status");
statusinfo.innerHTML = "第" + CurPage + "页";
}
}
NextPage切换下一页,调用TurnPage实现,如果下一页超出当前分组则要切换到下一分组。
function NextPage()
{
if (CurPage < TotalPage) {
TurnPage(CurPage+1);
if ((CurPage + 1) > (CurTab * PageTab)) {
TurnTab(1);
}
}
}
PreviousPage切换上一页,调用TurnPage实现,如果上一页超出当前分组则要切换到上一分组。
function PreviousPage()
{
if (CurPage > 1) {
TurnPage(CurPage-1);
if ((CurPage - 1) <= ((CurTab - 1) * PageTab)) {
TurnTab(-1);
}
}
}
_cscCustomAnalyst是异步调用函数,xhr.open("post","MapQuery.ashx", true);这段话是表示将请求提交到MapQuery.ashx这个页面。所有的服务器段数据库操作都在MapQuery.ashx里面执行。
function _cscCustomAnalyst(paramNames, paramValues, onComplete, onError){
var xhr=_GetXmlHttpRequest();
xhr.open("post","MapQuery.ashx", true);
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
xhr.onreadystatechange=function(){
var readyState=xhr.readyState;
if (readyState==4){
var status=xhr.status;
if(status==200){
var resultset = xhr.responseText;
if(resultset == null){
onComplete(null);
return;
}
if(onComplete){
onComplete(resultset);
resultset = null;
}
}
else{
if(onError){
onError(xhr.responseText);
}
}
xhr.onreadystatechange = function(){};
xhr = null;
}
};
var paramString=null;
if(paramNames&¶mNames.length>0){
var params = new Array();
while(paramNames&¶mNames.length>0)
{
params.push(paramNames.shift()+"="+_ToJSON(paramValues.shift()));
}
paramString = params.join("&");
}
xhr.send(paramString);
};
最后列出一个Oracle的按数量范围查询的SQL语句:(查询前50条记录)
SELECT *
FROM (SELECT /*+ FULL(tablename)*/ fieldname, ROWNUM rn FROM tablename WHERE condition AND ROWNUM <= 50 ORDER BY field DESC) t2 where t2.rn >= 1;
分享到:
相关推荐
总结起来,Ajax实现分页查询涉及客户端JavaScript的Ajax请求、服务器端JSP的处理以及前端的数据解析和展示。通过这种方式,你可以为用户提供流畅的分页体验,同时避免了页面的全量刷新。在实际项目中,还可以结合...
Ajax(Asynchronous JavaScript and XML)分页组件是利用JavaScript的异步特性来实现页面无刷新加载分页内容的技术,通常与Java后端配合使用。在本主题中,我们将深入探讨Ajax分页组件的实现原理、优势以及如何在Web...
Ext3-Js-Ajax框架-分页标签-自动排序-文件上传Ext-Js-Ajax框架-分页标签-自动排序-文件上传Ext-Js-Ajax框架-分页标签-自动排序-文件上传Ext-Js-Ajax框架-分页标签-自动排序-文件上传Ext-Js-Ajax框架-分页标签-自动...
这里我们讨论的“----------简易分页实现--------”项目,它使用了前后端结合的方式,通过后端的PageHelper插件和前端的jqPaginator库,以及Bootstrap框架来实现一个基础的分页功能。 首先,PageHelper是SpringMVC...
在这个案例中,我们将深入探讨如何在Java EE(J2EE)环境中实现Ajax分页,提升用户体验。 【描述】虽然描述信息为空,但通常Ajax分页的实现旨在提高数据加载效率,避免用户等待整个页面重新加载,尤其是在处理大量...
分页实现** 在Java Web开发中,分页通常有前端分页和后端分页两种方式。本项目采用的是后端分页,即服务器端处理分页逻辑,返回指定页码的数据。后端分页的优点是可以根据数据库的特性优化查询,减少网络传输的数据...
本示例是关于如何利用AJAX技术来实现一个GridView控件的分页功能。AJAX(Asynchronous JavaScript and XML)是一种在不刷新整个页面的情况下与服务器交换数据并更新部分网页的技术,它提供了更流畅的用户体验。 ...
Ajax-magento2-catalog-infinite-scroll.zip,免费的Magento 2扩展,为目录添加无限滚动功能(通过AJAX实现)编码教程,ajax代表异步javascript和xml。它是多种web技术的集合,包括html、css、json、xml和javascript。...
当我们结合这两者来实现分页条时,可以创建一个高效的、无刷新的页面,使用户能够轻松浏览大量数据。 **1. MVC模式解析** - **Model(模型)**:负责处理业务逻辑和数据操作,如从数据库中获取分页数据。 - **View...
在本项目中,“用ssm框架和Ajax写的分页查询”旨在实现一个能够动态加载数据并进行分页展示的功能。下面将详细阐述这个主题中的核心知识点。 1. **Spring框架**:Spring是一个全面的Java企业级应用开发框架,提供了...
本教程将围绕“ajax实现分页jquery代码”这一主题,详细介绍如何使用Ajax和jQuery实现动态分页,并讨论如何调整CSS以优化样式。 首先,我们需要引入jQuery库和jQuery分页插件。在HTML文件中,添加以下链接和脚本...
### 使用SSM框架中的Ajax实现自定义分页数据 在Web开发中,为了提升用户体验、减少服务器负担,分页功能的实现变得尤为重要。而在实际应用中,Ajax技术因其能够实现局部刷新、异步加载等功能而被广泛应用于动态加载...
在这个特定的【标题】"Ajax无刷新分页代码 - ASP源码.zip"中,我们可以预期包含的是一个使用ASP(Active Server Pages)语言实现的Ajax分页功能的源代码示例。 ASP是微软公司推出的一种服务器端脚本环境,用于创建...
总结来说,实现Java AJAX分页和JSP分页涉及前后端的协作。前端通过AJAX与后端通信,后端处理请求并从数据库获取数据,然后将数据返回给前端,前端再更新页面内容。这个过程提升了用户体验,使得浏览大数据集变得更加...
本文将详细介绍如何使用Ajax技术实现分页功能,特别是在Oracle数据库背景下。 首先,理解Ajax(Asynchronous JavaScript and XML)的核心概念:它是异步的JavaScript和XML技术,通过在后台与服务器交换少量数据,...
在网页开发中,数据分页是一项非常常见的功能,特别是在处理大量数据时,为了提高用户体验,避免一次性加载所有数据导致页面加载缓慢,我们会采用Ajax技术来实现动态分页。Ajax(Asynchronous JavaScript and XML)...
在本主题中,我们将深入探讨如何使用jQuery库中的AJAX方法来实现后台数据的分页功能。 首先,我们需要理解分页的基本原理。通常,分页涉及两个主要部分:前端和后端。前端负责显示分页链接或导航,并处理用户的交互...
Jquery.Pagination.js + Jquery.Ajax + ASP.NET----无刷新分页Pagination 1.5.1,是在原作者基础上修改的,因为Pagination 1.5.1与它的低版本有很大的区别,所以在此实例中增加了新版的使用方法
本篇文章将深入探讨jQuery AJAX分页的原理与实践,通过具体的实例来展示如何实现炫酷的分页功能。 首先,理解jQuery AJAX的核心概念。AJAX允许我们在不刷新整个页面的情况下,与服务器交换数据并更新部分网页内容。...