ajax分页 asp.net分页,asp.net+ajax简单分页实例分析-程序员宅基地

技术标签: ajax分页 asp.net分页  

本文实例讲述了asp.net+ajax简单分页实现方法。分享给大家供大家参考,具体如下:

这里涉及两个.aspx文件,一个叫Default.aspx,一个叫AjaxOperations.aspx,第一个用来显示一些测试数据,后一个用来对分页进行处理。js文件夹下面还有一个testJs.js的文件,它就是ajax操作的核心部分。不错,code is cheap。看代码:

/*testJs.js*/

// 此函数等价于document.getElementById /document.all

function $(s) { if (document.getElementById) { return eval('document.getElementById("' + s + '")'); } else { return eval('document.all.' + s); } }

// 创建 XMLHttpRequest对象,以发送ajax请求

function createXMLHTTP() {

var xmlHttp = false;

var arrSignatures = ["MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0",

"MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP",

"Microsoft.XMLHTTP"];

for (var i = 0; i < arrSignatures.length; i++) {

try {

xmlHttp = new ActiveXObject(arrSignatures[i]);

return xmlHttp;

}

catch (oError) {

xmlHttp = false; //ignore

}

}

// throw new Error("MSXML is not installed on your system.");

if (!xmlHttp && typeof XMLHttpRequest != 'undefined') {

xmlHttp = new XMLHttpRequest();

}

return xmlHttp;

}

//window.onload = showPages(1, 10, 100);

//cP目前页码, tP总页数 ,tN总记录数

function showPages(cP, tP, tN) {

//处理页码大于总页数

if (cP >= tP) {

cP = tP;

}

//处理页码小于1

if (cP < 1) {

cP = 1;

}

var trPg = $("trPager");

var newCellOne = trPg.insertCell(0);

newCellOne.width = "20%";

var newCellTwo = trPg.insertCell(1);

newCellTwo.width = "15%";

newCellTwo.id = "pgSummary";

var newCellThree = trPg.insertCell(2);

newCellThree.width = "45%";

newCellThree.id = "pgNumContext";

var newCellFour = trPg.insertCell(3)

newCellFour.width = "20%";

newCellTwo.innerHTML = "共" + tN + "项 第" + cP + "/" + tP + "页";

var pageHtml = " 首页";

pageHtml += " 上页 ";

for (var i = 1; i < tP + 1; i++) {

var numColor = "";

if (i == 1) numColor = "red";

pageHtml += "" + i + " ";

}

pageHtml += " 下页";

pageHtml += " 尾页";

pageHtml += "  " +

"";

newCellThree.innerHTML = pageHtml;

}

//构造页面跳转的js函数,函数中需要判断输入的页号是否是合法的数值

function forward() {

if (!(/^([-]){0,1}([0-9]){1,}$/.test($("pgNumber").value))) {

//输入的值不合法

alert("请输入合法的页号!");

$("pgNumber").focus();

$("pgNumber").select();

}

else

gotoPage($("pgNumber").value);

}

//处理在跳转页面上按下回车的情况

function handleEnterOnPgNumber() {

if (event.keyCode == 13) {

forward();

return false;

}

return true;

}

function gotoPage(oNum) { // 页数不能为0或者为负数 (首页,尾页)

if (oNum > 0) {

var totalNumber = parseInt($("totalNum").innerText); //总记录数

var curPgNumber = parseInt($("cuPgNumber").innerText);

var totalPgNumber = parseInt($("sumPgNumber").innerText); // 总页数

if (parseInt(oNum) <= totalPgNumber) {

chgPages(oNum, totalPgNumber, totalNumber);

for (var k = 1; k < totalPgNumber + 1; k++) {

$("numPg" + k).style.color = "";

}

$("numPg" + oNum).style.color = "red";

getPagerInfo(oNum);

}

else {

alert("请输入合法的页号!");

$("pgNumber").focus();

$("pgNumber").select();

return;

}

}

}

function goToNextPrev(oNum) {

var addNum = parseInt(oNum);

var totalNumber = parseInt($("totalNum").innerText); //总记录数

var curPgNumber = parseInt($("cuPgNumber").innerText);

var totalPgNumber = parseInt($("sumPgNumber").innerText); // 总页数

//如果当前页是第一页,点击前一页不用刷新 //如果当前页是最后一页,点击下一页不用刷新

if ((curPgNumber + addNum) > 0 && (curPgNumber + addNum) <= totalPgNumber) {

chgPages(parseInt(curPgNumber + addNum), totalPgNumber, totalNumber);

for (var k = 1; k < totalPgNumber + 1; k++) {

$("numPg" + k).style.color = "";

}

$("numPg" + parseInt(curPgNumber + addNum)).style.color = "red";

getPagerInfo(parseInt(curPgNumber + addNum));

}

}

function chgPages(cuPg, toPg, tNum) {

// $("totalNum").innerHTML = tNum;

$("cuPgNumber").innerHTML = cuPg;

//$("sumPgNumber").innerHTML = toPg;

}

function getPagerInfo(oNum) { // 处理请求,更新内容

var xmlReq = createXMLHTTP();

xmlReq.open("post", "/AjaxOperations.aspx?pgNumber=" + oNum, true);

xmlReq.onreadystatechange = function() {

if (xmlReq.readyState == 4) {

if (xmlReq.status == 200) {

//xmlReq.responseText为输出的那段字符串

$("tbTest").innerHTML = xmlReq.responseText;

}

else {

$("tbTest").innerHTML = "  获取数据中,请稍等...";

//alert("Connect the server failed!");

}

}

}

xmlReq.send(null);

}

Default.aspx:

A:link

{

color: #003399;

text-decoration: none;

}

A:visited

{

color: #003366;

text-decoration: none;

}

A:hover

{

color: #ff0000;

text-decoration: underline;

}

A:active

{

color: #00ff00;

text-decoration: none;

}

第1页

Default.aspx.cs:

using System;

using System.Collections.Generic;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

namespace WebTest2008

{

public partial class Default : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

}

}

}

AjaxOperations.aspx:

AjaxOperations.aspx.cs:

using System;

using System.Collections.Generic;

using System.Web;

using System.Web.UI;

using System.Web.UI.WebControls;

namespace WebTest2008

{

public partial class AjaxOperations : System.Web.UI.Page

{

protected void Page_Load(object sender, EventArgs e)

{

if (!string.IsNullOrEmpty(Request["pgNumber"]))

{

//int pgNum = Convert.ToInt32(Request["pgNumber"]);

Response.Write("第" + Request["pgNumber"] + "页");

}

}

}

}

Ok了,在我的机器上(vs2008)测试通过,简单的ajax分页效果就实现了。

希望本文所述对大家ajax程序设计有所帮助。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39983223/article/details/119437201

智能推荐

SAP HANA数据库数据类型、函数用法、SQL语法-程序员宅基地

文章浏览阅读2.2k次。SAP HANA数据库数据类型、函数用法、SQL语法_hana数据库

android Checkbox更换按钮颜色_代码设置checkbox的buttontint-程序员宅基地

文章浏览阅读1.6k次。android checkbox复选框更换按钮颜色_代码设置checkbox的buttontint

spring cloud 非web请求feign调用header携带数据_requesttemplate.header-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏5次。首先,在我之前的博文中我们介绍了feign调用携带token的解决放法,但是那仅适用于前端发起请求从controller层进入service层产生微服务之间的调用问题。实际开发场景中我们可能遇到很多非web请求,比如定时任务等在之前的基础上我们继续编程,直接上代码@Configurationpublic class FeignConfig implements RequestInterceptor { @Override public void apply(RequestTemp_requesttemplate.header

Python实现迪杰斯特拉算法和贝尔曼福特算法求解最短路径_使用迪杰斯特拉算法获得从源结点(source)到目的结点的最短路径长度-程序员宅基地

文章浏览阅读2k次,点赞3次,收藏24次。(一)、题目本题采用带权无向图作为例子。要求实现:绘制带权无向图获得从源结点到目的结点的最短路径所有结点两两之间的最短路径实现最短路径高亮(二)、导库最短路径问题主要使用的库是:networkx——内置常用的图与复杂网络分析算法matplotlib——使用matplotlib库进行绘图import networkx as nx #内置常用的图与复杂网络分析算法..._使用迪杰斯特拉算法获得从源结点(source)到目的结点的最短路径长度

程序员实用算法.pdf免费下载_程序员算法pdf 网盘下载-程序员宅基地

文章浏览阅读1.5k次。《程序员实用算法》重点关注的是实用、立即可用的代码,并且广泛讨论了可移植性和特定于实现的细节。《程序员实用算法》作者介绍了一些有用但很少被讨论的算法,它们可用于语音查找、日期和时间例程(直到公元1年)、B树和索引文件、数据压缩、任意精度的算术、校验和与数据验证,并且还最全面地介绍了查找例程、排序算法和数据结构。译者序前言致谢第1章 绪论1.1 评估算法1.2 修改算法1_程序员算法pdf 网盘下载

Python做的一个精简版学生信息管理系统【简单】【实用】_学生信息管理系统开发(简单版)。 功能能点: 展示学生信息-程序员宅基地

文章浏览阅读4.5k次,点赞9次,收藏46次。因为最近打算开发一个信息管理系统,有点复杂。作为初学者的我不是很懂。所以从简单的开始,先练练手。一步一步来,踏踏实实的走。千里之行始于足下。所以参考网上的一片技术文章,稍微修改了一下,做了这个系统。截图:废话不多说,上代码!代码:student_information.py#!/usr/bin/python# -*- coding: UTF-8 -*-students = ..._学生信息管理系统开发(简单版)。 功能能点: 展示学生信息

随便推点

初始mach-o文件及在项目中应用-程序员宅基地

文章浏览阅读494次,点赞5次,收藏4次。本文字数:2250字预计阅读时间:15分钟01认识mach-o的必要性了解mach-o的结构可以帮助认识系统加载二进制文件的动态链接和静态链接。应用层面,使用initialize的c++函数计算启动时间耗时也需要以mach-o的结构知识为铺垫。还可以用在使用clang自注册启动任务上。后续会一一展开说明。02mach-o的定义mach-o是mach object的缩写,是存储程序或库的标准格式。a...

法线贴图的原理和实现-程序员宅基地

文章浏览阅读160次。本文出自:http://shiba.hpe.sh.cn/jiaoyanzu/wuli/showArticle.aspx?articleId=328&classId=4法线映射可以让由少量多边形构成的模型看起来像是由大量多边形构成的一样,无需添加更多的多边形。使用法线映射可以使表面(如墙壁)看起来更加富有细节和真实。展示法线映射的一个简单方法是模拟几何形状。要计算法线映射我们需要两个..._家具法线贴图的使用和原理、

vue商品秒杀倒计时-程序员宅基地

文章浏览阅读871次。今天做项目需要倒计时具体代码如下:showTimes(val) { let that = this; let interval = setInterval(() => { let nowTime = new Date().getTime(); let startDate = that.obj.endTime; startDate = startDate.replace(new RegExp('-', 'gm'), '/'); let startDate

[javascript]关于帧动画的操作_js逐帧动画-程序员宅基地

文章浏览阅读597次。使用css或者css+js实现帧动画。_js逐帧动画

【图像拼接】SIFT+RANSAC图像拼接与融合【含Matlab源码 3231期】-程序员宅基地

文章浏览阅读1.1k次,点赞27次,收藏12次。SIFT+RANSAC图像拼接与融合完整代码,直接运行,适合小白!可提供运行操作视频!

vmwareworkstation的linux虚拟机关闭屏保【自动锁屏】,掌门一对一java面试题_linux虚拟机如何取消锁屏-程序员宅基地

文章浏览阅读370次,点赞4次,收藏6次。给大家送一个小福利附高清脑图,高清知识点讲解教程,以及一些面试真题及答案解析。送给需要的提升技术、准备面试跳槽、自身职业规划迷茫的朋友们。跳槽、自身职业规划迷茫的朋友们。[外链图片转存中…(img-VzhL7L8l-1711087689878)]本文已被CODING开源项目:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】收录。_linux虚拟机如何取消锁屏