`
snake_hand
  • 浏览: 624806 次
社区版块
存档分类
最新评论

JQuery实现分页程序代码,源码下载

 
阅读更多

Web开发,分页在所难免的,微软GridView、AspPager等设置分页数据可以自动分页,但是这里浏览器会闪动,用户体验不是很友好,在此我整理了JQuery实现分页,并且使用

JQuery模板显示数据,用户体验很友好

项目结构:

jquery.tools.pack.js是Jquery数据显示模板

Default.aspx显示分页数据,Member_Ajax.aspx是将数据已JSON格式输出到页面,PageBar.cs分页工具条,Student.cs实体类

首先Default.aspx页面需要引用的JS文件

JQuery采用 1.4.1.1 下载地址:http://pan.baidu.com/share/link?shareid=3024434948&uk=2920032010

JQuery数据显示模板JS 下载地址:http://pan.baidu.com/share/link?shareid=3030793948&uk=2920032010

分页按钮样式 下载地址:http://pan.baidu.com/share/link?shareid=3146737028&uk=2920032010

Default.aspx页面js代码,如下,每页条数可以自定义,也可以放置配置文件中,queryString函数是根据URL参数名称,获取参数的值

<script type="text/javascript">
        var pagesize = 10;
        var page = thispage();
        $(document).ready(function () {
            ajaxList(page);
        });

        function queryString(pname) {
            var query = location.search.substring(1);
            var str = "";
            params = query.split("&");
            if (params.length > 0) {
                for (var n in params) {
                    var pairs = params[n].split("=");
                    if (pairs[0] == pname) {
                        str = pairs[1];
                        break;
                    }
                }
            }
            return str;
        }

        function thispage() {
            var r = /^[1-9][0-9]*$/;
            if (queryString('page') == '') return 1;
            if (r.test(queryString('page')))
                return parseInt(queryString('page'));
            else
                return 1;
        }

        function ajaxList(currentpage) {
            if (currentpage != null) page = currentpage;
            $.ajax({
                type: "get",//get类型,获取用QueryString方法,post类型,用Form获取传值
                dataType: "json",
                data: "pageIndex=" + currentpage + "&pagesize=" + pagesize + "&clienttt=" + Math.random(),
                url: "Member_Ajax.aspx",
                error: function (XmlHttpRequest, textStatus, errorThrown) { alert(XmlHttpRequest.responseText); },
                success: function (d) {
                    switch (d.result) {
                        case '-1':
                            Alert(d.returnval);
                            break;
                        case '0':
                            Alert(d.returnval);
                            break;
                        case '1':
                            $("#ajaxList").setTemplateElement("tplList", null, { filter_data: true });
                            $("#ajaxList").processTemplate(d);
                            $("#ajaxPageBar").html(d.pagebar);
                            break;
                    }
                }
            });
        }

 </script>

 
Default.aspx页面Form代码如下,页面数据使用JQuery jTemplates绑定数据,非常方便,只需设置JSON格式数据,引用JS文件即可

<textarea id="tplList" style="display: none">
            <table class="cooltable" width="300px">
            <thead>
                <tr>
                    <th align="center" scope="col" style="width:30px;"><input onclick="checkAllLine()" id="checkedAll" name="checkedAll" type="checkbox" title="全部选择/全部不选" /></th>
                    <th scope="col" style="width:60px;">ID</th>
                    <th width="120px">姓名</th>
                    <th scope="col" width="60px">年龄</th>
                    
               </tr>
            </thead>
            <tbody>
    {#foreach $T.table as record}
    <tr>
        <td align="center">
            <input class="checkbox" name="selectID" type="checkbox" value='{$T.record.MemberNo}' />
        </td>
        <td align="center">{$T.record.Id}</td>
        <td align="left">
            {$T.record.Name}
        </td>
        <td align="left">
            {$T.record.Age}
        </td>
    </tr>
    {#/for}
</tbody>
            </table>
     </textarea>
    <div id="ajaxList" style="width:500px;">
    </div><br />
    <div id="ajaxPageBar" style="width:500px;">
    </div>
View Code

$T.table.Id 中Id对应的是实体类Id属性,table是json格式中list集合名称


上面Javascript方法中用到Member_Ajax.aspx页面代码如下,注意:这里是将数据已JSON格式输出到页面,配合JQuery数据模板使用,所有Member_Ajax.aspx页面,不应该包含Html标签,其代码格式如下

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Member_Ajax.aspx.cs" Inherits="Nick.Kuang.Web.Member_Ajax" %>

Member_Ajax.aspx cs页面代码

protected void Page_Load(object sender, EventArgs e)
        {
            Response.Write(GetAll());
        }

        private string GetAll()
        {
            List<Student> list = new List<Student>();

            for (int i = 0; i < 100; i++)
            {
                list.Add(new Student { Id = i, Name = "Name" + i, Age = i });
            }
            
            int pageIndex = GetPage();
            int pageSize = StrToInt(QueryString("pagesize"), 10); ;
            JavaScriptSerializer javascriptSerializer = new JavaScriptSerializer();

            string result = javascriptSerializer.Serialize(list.Skip(pageSize * (pageIndex - 1)).Take(pageSize).ToList());
            string response = "{\"result\" :\"1\"," +
                "\"returnval\" :\"操作成功\"," +
                "\"pagebar\" :\"" + PageBar.GetPageBar(3, "js", 2, list.Count, pageSize, pageIndex, "javascript:ajaxList(<#page#>);") + "\"," +
               "\"" + "totalCountStr" + "\":" + 10 + ",\"" + "table" + "\":" + result + 
                "}";
            return response;
        }

        private static int GetPage()
        {
            int page = StrToInt(QueryString("pageIndex"), 0) < 1 ? 1 : StrToInt(QueryString("pageIndex"), 0);
            return page;
        }

        private static int StrToInt(string value, int defaultValue)
        {
            if (IsNumeric(value))
                return int.Parse(value);
            else
                return defaultValue;
        }

        /// <summary>
        /// 获取querystring
        /// </summary>
        /// <param name="s">参数名</param>
        /// <returns>返回值</returns>
        private static string QueryString(string s)
        {
            if (HttpContext.Current.Request.QueryString[s] != null && HttpContext.Current.Request.QueryString[s] != "")
            {
                return SafetyQueryS(HttpContext.Current.Request.QueryString[s].ToString());
            }
            return string.Empty;
        }

        /// <summary>
        /// 将字符串中的一些标签过滤
        /// </summary>
        /// <param name="theString"></param>
        /// <returns></returns>
        private static string SafetyQueryS(string theString)
        {
            string[] aryReg = { "'", ";", "\"", "\r", "\n", "<", ">" };
            for (int i = 0; i < aryReg.Length; i++)
            {
                theString = theString.Replace(aryReg[i], string.Empty);
            }
            return theString;
        }

        private static bool IsNumeric(string value)
        {
            System.Text.RegularExpressions.Regex myRegex = new System.Text.RegularExpressions.Regex("^[-]?[1-9]*[0-9]*$");
            if (value.Length == 0)
            {
                return false;
            }
            return myRegex.IsMatch(value);
        }
View Code

 

使用JavaScriptSerializer中的Serialize方法可以将Object类型数据转换成JSON格式的数据,告别以前拼接成字串的方法

Student实体类代码属性

public class Student
    {
        public int Id { get; set; }

        public string Name { get; set; }

        public int Age { get; set; }
    }
View Code


分页中用到的PageBar类代码,分页调用Default.aspx中ajaxList函数,实现无刷新分页

public class PageBar
    {
        /// <summary>
        /// 完整模式:数字+上下页+首末+总记录信息+指定页码翻转
     /// </summary>
        /// <param name="stype"></param>
        /// <param name="stepNum"></param>
        /// <param name="pageRoot"></param>
        /// <param name="pageFoot"></param>
        /// <param name="countNum"></param>
        /// <param name="currentPage"></param>
        /// <param name="Http1"></param>
        /// <param name="HttpM"></param>
        /// <param name="HttpN"></param>
        /// <param name="limitPage"></param>
        /// <returns></returns>
        private static string GetDetailbar(string stype, int stepNum, int pageRoot, int pageFoot, int pageCount, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage)
        {
            StringBuilder sb = new StringBuilder();
            sb.Append("<div class='p_btns'>");
            //sb.Append("<span class='total_count'>共" + countNum.ToString() + "条,当前第" + currentPage.ToString() + "/" + pageCount.ToString() + "页&nbsp;&nbsp;&nbsp;</span>");
            sb.Append("<span class='total_count'>共" + countNum.ToString() + "条记录/" + pageCount.ToString() + "页&nbsp;&nbsp;</span>");
            if (countNum > pageSize)
            {
                if (currentPage != 1)//只要不是第一页
                    sb.Append("<a target='_self' href='" + GetPageUrl(currentPage - 1, Http1, HttpM, HttpN, limitPage) + "' title='上一页'>&laquo;</a>");
                if (pageRoot > 1)
                {
                    sb.Append("<a target='_self' href='" + GetPageUrl(1, Http1, HttpM, HttpN, limitPage) + "'>1..</a>");
                }
                if (stepNum > 0)
                {
                    for (int i = pageRoot; i <= pageFoot; i++)
                    {
                        if (i == currentPage)
                            sb.Append("<span class='currentpage'>" + i.ToString() + "</span>");
                        else
                            sb.Append("<a target='_self' href='" + GetPageUrl(i, Http1, HttpM, HttpN, limitPage) + "'>" + i.ToString() + "</a>");
                        if (i == pageCount)
                            break;
                    }
                }
                if (pageFoot < pageCount)
                {
                    sb.Append("<a target='_self' href='" + GetPageUrl(pageCount, Http1, HttpM, HttpN, limitPage) + "'>.." + pageCount + "</a>");

                }
                if (currentPage != pageCount)//只要不是最后一页
                    sb.Append("<a target='_self' href='" + GetPageUrl(currentPage + 1, Http1, HttpM, HttpN, limitPage) + "' title='下一页'>&raquo;</a>");
                if (stype == "html")
                    sb.Append("<span class='jumppage'>转到第 <input type='text' name='custompage' size='2' onkeyup=\"this.value=this.value.replace(/\\D/g,'')\" onafterpaste=\"this.value=this.value.replace(/\\D/g,'')\" onkeydown=\"if(event.keyCode==13) {window.location='" + HttpN + "'.replace('<#page#>',this.value); return false;}\" /> 页</span>");
            }
            sb.Append("</div>");
            return sb.ToString();
        }

        /// <summary>
        /// 分页导航
        /// </summary>
        /// <param name="mode">支持1=simple,2=normal,3=full</param>
        /// <param name="stype">html/js,只有当stype为html且mode为3的时候显示任意页的转向</param>
        /// <param name="stepNum">步数,如果步数为i,则每页的数字导航就有2i+1</param>
        /// <param name="countNum">记录总数</param>
        /// <param name="pageSize">每页记录数</param>
        /// <param name="currentPage">当前页码</param>
        /// <param name="Http1">第1页的链接地址模板,支持js</param>
        /// <param name="HttpM">第M页的链接地址模板,支持js,M不大于limitPage</param>
        /// <param name="HttpN">第N页的链接地址模板,支持js,N大于limitPage</param>
        /// <param name="limitPage"></param>
        /// <returns></returns>
        public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string Http1, string HttpM, string HttpN, int limitPage)
        {
            string pagebar = "";
            //if (countNum > pageSize)
            //{
            int pageCount = countNum % pageSize == 0 ? countNum / pageSize : countNum / pageSize + 1;
            currentPage = currentPage > pageCount ? pageCount : currentPage;
            currentPage = currentPage < 1 ? 1 : currentPage;
            int stepageSize = stepNum * 2;
            int pageRoot = 1;
            int pageFoot = pageCount;
            pageCount = pageCount == 0 ? 1 : pageCount;
            if (pageCount - stepageSize < 1)//页数比较少
            {
                pageRoot = 1;
                pageFoot = pageCount;
            }
            else
            {
                pageRoot = currentPage - stepNum > 1 ? currentPage - stepNum : 1;
                pageFoot = pageRoot + stepageSize > pageCount ? pageCount : pageRoot + stepageSize;
                pageRoot = pageFoot - stepageSize < pageRoot ? pageFoot - stepageSize : pageRoot;
            }
           
            pagebar = GetDetailbar(stype, stepNum, pageRoot, pageFoot, pageCount, countNum, pageSize, currentPage, Http1, HttpM, HttpN, limitPage);
                 
            return pagebar;
        }

        public static string GetPageBar(int mode, string stype, int stepNum, int countNum, int pageSize, int currentPage, string HttpN)
        {
            return GetPageBar(mode, stype, stepNum, countNum, pageSize, currentPage, HttpN, HttpN, HttpN, 0);
        }

        public static string GetPageUrl(int chkPage, string Http1, string HttpM, string HttpN, int limitPage)
        {
            string Http = string.Empty;
            if (chkPage == 1)
                Http = Http1;
            else
                Http = (chkPage > limitPage || limitPage == 0) ? HttpN : HttpM;
            return Http.Replace("<#page#>", chkPage.ToString());
        }
    }    
View Code

 

最后的效果是,如下图


代码基本上写好了,希望对大家有用,一起学习,一起进步

源码下载:http://pan.baidu.com/share/link?shareid=2604334191&uk=2920032010

 

 

0
2
分享到:
评论

相关推荐

    jquery +asp.net MVC+多种分页样式源码

    开发者可以通过查看和学习源码了解如何在ASP.NET MVC项目中集成jQuery分页插件,以及如何实现各种分页样式的动态切换。 5. **实际应用**:在实际开发中,这个源码可以作为基础模板,用于快速搭建具有分页功能的Web...

    Jquery easyUI分页实现

    总的来说,jQuery EasyUI的分页功能对于构建数据密集型的Web应用程序非常有用。通过合理配置和事件处理,我们可以创建出既美观又实用的分页界面,提升用户的操作体验。学习和掌握这一技能,将对开发高效的数据展示...

    .net 类的JQuery分页.net 类的JQuery分页

    在实现jQuery分页时,可能需要在`web.config`中配置路由规则,以便正确地处理分页请求,并确保相关的Handler能被正确调用。此外,也可能需要配置数据库连接字符串等其他与数据访问相关的信息。 `Default.aspx`是ASP...

    存储过程之jQuery分页源码

    开发人员可以参考"51aspx源码必读.txt"学习如何将存储过程与jQuery分页源码结合,通过"DBUtility"中的函数调用存储过程,实现数据的分页加载,同时利用"Northwind.sln"中的项目结构和代码作为参考,优化自己的应用...

    JQuery实现ajax上传文件示例源码20121029

    JQuery实现ajax上传文件示例源码 源码描述: url用来指定后台处理的程序,fileElementId指的是文件选择框的ID,dataType用来指定返回的数据格式,支持xml、script、json和html。 返回的json的格式最简单:{error:'...

    [精华]网站论坛源码C# Jquery,完全自制,有很多jquery自己写的插件

    这些标签帮助我们理解该论坛项目的技术栈和特点:C#用于服务器端处理,Jquery负责客户端交互,"论坛"是指应用类型,"源码"意味着我们可以查看和学习整个项目的代码,"插件"则表示这个项目在Jquery的基础上扩展了...

    jquery-easyui-1.5完整源码.zip

    在"jquery-easyui-1.5完整源码.zip"这个压缩包中,包含了EasyUI 1.5版本的完整源代码,这对于我们深入理解其工作原理、定制功能或优化性能具有极大的帮助。 首先,我们关注的是"src"文件夹。这个文件夹中的内容是...

    MvcPager分页示例MVC2.0源码

    MvcPager分页控件是在ASP.NET MVC Web应用程序中实现分页功能的一系列扩展方法,该分页控件的最初的实现方法借鉴了网上流行的部分源代码,尤其是ScottGu的PagedList类和相关方法,经过站长不断完善和改进后推出的...

    ASP.NET源码——jquery无刷新分页、排序.zip

    文件名称"其他类别]jquery无刷新分页、排序_jquerypager"可能指的是一个特定的jQuery分页插件,如jQueryPager,它可能提供了更简便的API来实现分页功能。 总的来说,这个项目涵盖了客户端脚本(jQuery)与服务器端...

    ajax+jquery分页控件(asp.net)

    9. **最新Asp.Net源码下载.url**:这是一个网址链接,指向更多ASP.NET相关的源码下载资源。 10. **JS**:这可能是一个包含JavaScript代码的文件夹,其中可能包含实现分页功能的jQuery脚本。 11. **App_Data**:这...

    一个基于C#+ASP.NET实现的仿QQ拖动分页功能程序源码例子

    这个C#+ASP.NET实现的程序源码例子,就是将这种功能引入到Web应用中,使得用户可以通过拖动页面来浏览不同分页的内容,而无需点击传统的“上一页”或“下一页”按钮。 首先,我们要理解C#和ASP.NET的基础知识。C#是...

    jquery+json实现页面无刷新分页

    对于"jquery-pager"这个文件,它可能是实现上述分页逻辑的一个插件或者代码示例。通常,这样的插件会提供预定义的样式和事件处理,简化开发过程。开发者只需要按照文档配置和调用,即可快速实现分页功能。 总的来说...

    关于Struts2与Jquery实现无刷新分页的不解问题

    3. **jQuery分页插件**: jQuery有许多分页插件可供选择,如jQuery Pagination。引入所需的CSS和JavaScript文件,然后在HTML页面中设置分页组件。例如,可以使用以下代码创建分页导航: ```html ...

    20120102 NET+jQuery 实现局部刷新+分页+高亮显示搜索内容

    综合以上信息,这份资源可能是关于使用C#和ASP.NET开发Web应用的实例,其中涵盖了使用jQuery实现Ajax局部刷新、分页和搜索结果高亮的功能,并且附带了完整的源代码。对于想要提升.NET Web开发技能,特别是对jQuery...

    一个JQuery实现的带分页头像选择列表。

    通过阅读这篇文章,读者可以学习到关于JQuery分页头像选择列表的具体实现步骤、代码示例以及可能遇到的问题和解决方案。 从标签“源码 工具”来看,这个压缩包可能包含了一个实际的源代码文件,用于实现上述功能,...

    spring+springMVC+mybatis+easyui 增删查改以及分页源码

    标题 "spring+springMVC+mybatis+easyui 增删查改以及分页源码" 描述了一个使用SSM(Spring、SpringMVC、MyBatis)框架与EasyUI前端库联合实现的Web应用项目,特别是关注于CRUD(创建、读取、更新、删除)操作和无...

    springMVC+spring+hibernate+jquery分页完整项目,完整代码

    在这个项目中,SpringMVC和Hibernate结合,实现了后端的分页处理,而jQuery则负责前端的分页展示和交互,用户可以轻松地浏览和切换页面。 6. 项目结构: - `.classpath` 和 `.project` 是Eclipse IDE的配置文件,...

Global site tag (gtag.js) - Google Analytics