1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > asp.net使用AJAX实现无刷新分页

asp.net使用AJAX实现无刷新分页

时间:2023-12-23 06:17:05

相关推荐

asp.net使用AJAX实现无刷新分页

后端开发|C#.Net教程

ajax分页

后端开发-C#.Net教程

查询功能是开发中最重要的一个功能,大量数据的显示,我们用的最多的就是分页。

大淘客淘口令源码下载,vscode怎么弹出输出框,调整ubuntu权限,怎么导入tomcat原码,电话采集爬虫,php函数传递数组,自贡seo推广怎么样,下载网站flash,网站建设模板免费下载lzw

在 中有很多数据展现的控件,比如Repeater、GridView,用的最多的GridView,它同时也自带了分页的功能。但是我们知道用GridView来显示数据,如果没有禁用ViewState,页面的大小会是非常的大的。而且平时我们点击首页,下一页,上一页,尾页这些功能都是会引起页面回发的,也就是需要完全跟服务器进行交互,来回响应的时间,传输的数据量都是很大的。

pc蛋蛋开奖源码破解,ubuntu开机延时配置,tomcat 多个一起部署,进阶狼爬虫,厦门php工资是多少,马桥镇seo优化lzw

AJAX的分页可以很好的解决这些问题。

c mvc 如何发布网站源码,vscode怎么开发界面,ubuntu存储结构,tomcat 远程执行,sqlite 数据库关联,Python爬虫怎么爬取p内容,js中写php,河源seo培训学校,网站评论模板代码,网页自动缩放代码,thinkcmf网站模板下载lzw

数据显示Pasing.aspx页面JS代码:

var pageIndex = 0; var pageSize = 5;window.onload = AjaxGetData(name,0,5);function AjaxGetData(name, index, size){ $.ajax({ url: jQueryPaging.aspx, type: Get, data: Name= + name + &PageIndex= + index + &PageSize= + size, dataType: json, success: function (data) {var htmlStr = ;htmlStr += htmlStr += htmlStr += htmlStr += ;htmlStr += //data.cloudfileLists.lengthfor (var i = 0; i < data.cloudfileLists.length; i++) { htmlStr += ; htmlStr += +htmlStr += ;}htmlStr += ;htmlStr += ;htmlStr += ;htmlStr += ;htmlStr += ;htmlStr += ;htmlStr +=

; $(#divSearchResult).html(htmlStr);//重写html }, error: function (XMLHttpRequest, textStatus, errorThrown) {alert(XMLHttpRequest);alert(textStatus);alert(errorThrown); } }); } //首页 function GoToFirstPage() { pageIndex = 0; AjaxGetData($(#txtSearch).val(), pageIndex, pageSize); } //前一页 function GoToPrePage() { pageIndex -= 1; pageIndex = pageIndex >= 0 ? pageIndex : 0; AjaxGetData($(#txtSearch).val(), pageIndex, pageSize); } //后一页 function GoToNextPage() { if (pageIndex + 1 < parseInt($(#count).text())) { pageIndex += 1; } AjaxGetData($(#txtSearch).val(), pageIndex, pageSize); } //尾页 function GoToEndPage() { pageIndex = parseInt($(#count).text()) - 1; AjaxGetData($(#txtSearch).val(), pageIndex, pageSize); } //跳转 function GoToAppointPage(e) { var page = $(e).prev().val(); if (isNaN(page)) { alert(请输入数字!); } else { var tempPageIndex = pageIndex; pageIndex = parseInt($(e).prev().val()) - 1; if (pageIndex = parseInt($(#count).text())) {pageIndex = tempPageIndex;alert(请输入有效的页面范围!); } else {AjaxGetData($(#txtSearch).val(), pageIndex, pageSize); } } }

同一页面HTML代码:

jQueryPaging.aspx页面的CS代码如下:

引用这个命名空间:using System.Web.Script.Serialization;//JavaScriptSerializer要用的。

protected void Page_Load(object sender, EventArgs e){ Int32 pageIndex = Int32.MinValue; Int32 pageSize = Int32.MinValue; String name = String.Empty; JavaScriptSerializer jss = new JavaScriptSerializer(); if (Request[Name] != null) { name = Request[Name].ToString(); if (Request[PageIndex] != null) { pageIndex = Int32.Parse(Request[PageIndex].ToString()); pageSize = Request[PageSize] != null ? Int32.Parse(Request[PageSize].ToString()) : 5; IList cloudfileLists = new List();//cloudfile是自己写的类,表示一条数据 CloudFile cf = null; int cout = 0; DataSet ds = LookDataFromDB(name, pageIndex, pageSize,out cout); foreach (DataRow row in ds.Tables[0].Rows)//把你的数据重新封装成Lis,才能被jss.Serialize(),不然会报错。 {cf = new CloudFile();cf.FileID = row[FilePathId].ToString();cf.FileName = row[FileName].ToString();cloudfileLists.Add(cf); } if (cloudfileLists.Count > 0) {Response.Write({Count: + (cout) + ,cloudfileLists: + jss.Serialize(cloudfileLists) + });Response.End(); } } }}private DataSet LookDataFromDB(string name, int pageIndex, int pageSize,out int cout){ DataSet ds = new DataSet(); try { pageIndex = 5 * pageIndex;//pageIndex ,表示这一页从哪一条数据开始 // 这里写自己的数据获取方法,把数据获取好了甩到ds里面,返回到前面。(应该有更好的办法,自己想哦,也可以发评论我们一起探讨....。) } catch (Exception) { cout = 0; ds = null; } return ds;}

//CloudFile类

public class CloudFile { public String FileID { get; set; } public String FileName { get; set; } public String FileDirName { get; set; } }

这样一个简单的无刷新分页的实例就完成了。由于本人的JS水平有限,现在只能做到这了。当然还可以添加一些新的功能。这里我只是想将我的方法与大家分享。至于功能,待以后继续完善了!!!

更多使用AJAX实现无刷新分页相关文章请关注PHP中文网!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。