热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

自己写的分页代码简洁实用

效果图如下:前台代码:

效果图如下:


前台代码:

<%&#64; Page Language&#61;"C#" AutoEventWireup&#61;"true" CodeFile&#61;"01.aspx.cs" Inherits&#61;"_01" %>

DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns&#61;"http://www.w3.org/1999/xhtml">
<head runat&#61;"server">
    
<title>title>
    
<link href&#61;"css/css.css" rel&#61;"stylesheet" type&#61;"text/css" />
head>
<body>
    
<form id&#61;"form1" runat&#61;"server">
    
<div>
        
<asp:Repeater ID&#61;"rptTest" runat&#61;"server">
            
<HeaderTemplate><table class&#61;"border">HeaderTemplate>
            
<ItemTemplate><tr><td class&#61;"td"><%#Eval("id")%>td><td class&#61;"td"><%#Eval("title")%>td><td class&#61;"td"><%#Eval("usercode")%>td>tr>ItemTemplate>
            
<FooterTemplate>table>FooterTemplate>
        
asp:Repeater>
    
div>
     
<br />
    
<div id&#61;"wayduPager">
          第
<asp:Label ID&#61;"lblPageIndex" runat&#61;"server" Text&#61;"1" ForeColor&#61;"Red">asp:Label>页/总<asp:Label ID&#61;"lblMaxPage" runat&#61;"server" Text&#61;"1" ForeColor&#61;"Red">asp:Label> | 每页<asp:Label ID&#61;"lblPageSize" runat&#61;"server" Text&#61;"1" ForeColor&#61;"Red">asp:Label>  <asp:Label ID&#61;"lblTotalCount" runat&#61;"server" Text&#61;"1" ForeColor&#61;"Red">asp:Label> | <asp:LinkButton ID&#61;"lnkFirst" OnClick&#61;"lnkFirst_Click" runat&#61;"server">首 页asp:LinkButton> | <asp:LinkButton ID&#61;"lnkPrev" OnClick&#61;"lnkPrev_Click" runat&#61;"server">上一页asp:LinkButton> | <asp:LinkButton ID&#61;"lnkNext" OnClick&#61;"lnkNext_Click" runat&#61;"server">下一页asp:LinkButton> | <asp:LinkButton ID&#61;"lnkLast" OnClick&#61;"lnkLast_Click" runat&#61;"server">尾 页asp:LinkButton> | 转到&#xff1a;第<asp:DropDownList ID&#61;"ddlselectPage" runat&#61;"server" AutoPostBack&#61;"True" OnSelectedIndexChanged&#61;"ddlselectPage_SelectedIndexChanged">asp:DropDownList>
    
div>
    
form>
body>
html>

后台代码&#xff1a;

using System;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

using System.Data;

public partial class _01 : System.Web.UI.Page
{

    
protected void Page_Load(object sender, EventArgs e)
    {
        
if(!IsPostBack)
        {
            BindList();
        }
    }

    
#region 绑定数据源
    
private void BindList()
    {
        
string sql &#61; " select id,title,memberid,(select usercode from t_mem_memberinfo where memberid&#61;a.memberid) as usercode from t_blog a order by id desc ";
        DataSet ds 
&#61; sqlDatabase.getDS(sql);
        
//-----------------------分页代码-----------------------//
        PagedDataSource Pds &#61; new PagedDataSource();
        Pds.DataSource 
&#61; ds.Tables[0].DefaultView;

        Pds.AllowPaging 
&#61; true//开启分页
        Pds.PageSize &#61; 15//分页

        
int index &#61; int.Parse(lblPageIndex.Text); //当前页数
        int PageSize &#61; Pds.PageSize;              //每页记录数
        int TotalRecords &#61; Pds.DataSourceCount;   //总记录数
        int TotalPages &#61; TotalRecords / PageSize;//总页数&#xff08;总记录数除以每页的记录数&#xff09; 
        int ModePages &#61; TotalRecords % PageSize;//得到取模的余数(总记录数取模每页的记录数) 

        
if (ModePages > 0)//如果取模数不等于0&#xff0c;则把总页数加1 
        {
            TotalPages 
&#43;&#61; 1;
        }
        
if (TotalPages &#61;&#61; 0)
        {
            TotalPages 
&#61; 1;
        }
        
this.ViewState["TotalPages"&#61; TotalPages;    //保存"总页数"到页面视图中

        lblMaxPage.Text 
&#61; TotalPages.ToString();      //显示页面上的总页数 
        lblTotalCount.Text &#61; TotalRecords.ToString(); //显示页面上的总记录数 
        lblPageSize.Text &#61; Pds.PageSize.ToString();   //每页记录数
        Pds.CurrentPageIndex &#61; index - 1;
        
//若是"第一页"
        if (index &#61;&#61; 1)
        {
            lnkFirst.Enabled 
&#61; false;
            lnkPrev.Enabled 
&#61; false;
            
if (TotalPages > 1)
            {
                lnkNext.Enabled 
&#61; true;
                lnkLast.Enabled 
&#61; true;
            }
            
else
            {
                lnkNext.Enabled 
&#61; false;
                lnkLast.Enabled 
&#61; false;
            }
        }
        
else
        {
            lnkFirst.Enabled 
&#61; true;
            lnkPrev.Enabled 
&#61; true;
            
//若是"尾页"
            if (index &#61;&#61; TotalPages)
            {
                lnkNext.Enabled 
&#61; false;
                lnkLast.Enabled 
&#61; false;
            }
            
else
            {
                lnkNext.Enabled 
&#61; true;
                lnkLast.Enabled 
&#61; true;
            }
        }

        ddlselectPage.Items.Clear(); 
//清除防止累加
        for (int i &#61; 1; i <&#61; TotalPages; i&#43;&#43;)
        {
            ddlselectPage.Items.Add(i.ToString());
        }
        ddlselectPage.Items.FindByText(index.ToString()).Selected 
&#61; true//把当前页显示在列表框的第一个

        
this.rptTest.DataSource &#61; Pds;
        
this.rptTest.DataBind();
    }
    
#endregion

    
#region "首页"事件
    
protected void lnkFirst_Click(object sender, EventArgs e)
    {
        
int index &#61; 1;
        lblPageIndex.Text 
&#61; index.ToString();
        BindList();
    }
    
#endregion

    
#region "上一页"事件
    
protected void lnkPrev_Click(object sender, EventArgs e)
    {
        
int index &#61; int.Parse(lblPageIndex.Text);
        index
--;
        lblPageIndex.Text 
&#61; index.ToString();
        BindList();
    }
    
#endregion

    
#region "下一页"事件
    
protected void lnkNext_Click(object sender, EventArgs e)
    {
        
int index &#61; int.Parse(lblPageIndex.Text);
        index
&#43;&#43;;
        lblPageIndex.Text 
&#61; index.ToString();
        BindList();
    }
    
#endregion

    
#region "尾页"事件
    
protected void lnkLast_Click(object sender, EventArgs e)
    {
        
int index &#61; Convert.ToInt32(this.ViewState["TotalPages"].ToString());
        lblPageIndex.Text 
&#61; index.ToString();
        BindList();
    }
    
#endregion

    
#region "转到"事件
    
protected void ddlselectPage_SelectedIndexChanged(object sender, EventArgs e)
    {
        lblPageIndex.Text 
&#61; ddlselectPage.SelectedValue;
        BindList();
    }
    
#endregion
}



推荐阅读
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 本文探讨了使用JavaScript在不同页面间传递参数的技术方法。具体而言,从a.html页面跳转至b.html时,如何携带参数并使b.html替代当前页面显示,而非新开窗口。文中详细介绍了实现这一功能的代码及注释,帮助开发者更好地理解和应用该技术。 ... [详细]
  • 本文详细介绍了一种利用 ESP8266 01S 模块构建 Web 服务器的成功实践方案。通过具体的代码示例和详细的步骤说明,帮助读者快速掌握该模块的使用方法。在疫情期间,作者重新审视并研究了这一未被充分利用的模块,最终成功实现了 Web 服务器的功能。本文不仅提供了完整的代码实现,还涵盖了调试过程中遇到的常见问题及其解决方法,为初学者提供了宝贵的参考。 ... [详细]
  • 本文详细探讨了 jQuery 中 `ajaxSubmit` 方法的使用技巧及其应用场景。首先,介绍了如何正确引入必要的脚本文件,如 `jquery.form.js` 和 `jquery-1.8.0.min.js`。接着,通过具体示例展示了如何利用 `ajaxSubmit` 方法实现表单的异步提交,包括数据的发送、接收和处理。此外,还讨论了该方法在不同场景下的应用,如文件上传、表单验证和动态更新页面内容等,提供了丰富的代码示例和最佳实践建议。 ... [详细]
  • 为了确保iOS应用能够安全地访问网站数据,本文介绍了如何在Nginx服务器上轻松配置CertBot以实现SSL证书的自动化管理。通过这一过程,可以确保应用始终使用HTTPS协议,从而提升数据传输的安全性和可靠性。文章详细阐述了配置步骤和常见问题的解决方法,帮助读者快速上手并成功部署SSL证书。 ... [详细]
  • 本文介绍了如何利用Struts1框架构建一个简易的四则运算计算器。通过采用DispatchAction来处理不同类型的计算请求,并使用动态Form来优化开发流程,确保代码的简洁性和可维护性。同时,系统提供了用户友好的错误提示,以增强用户体验。 ... [详细]
  • 在处理 XML 数据时,如果需要解析 `` 标签的内容,可以采用 Pull 解析方法。Pull 解析是一种高效的 XML 解析方式,适用于流式数据处理。具体实现中,可以通过 Java 的 `XmlPullParser` 或其他类似的库来逐步读取和解析 XML 文档中的 `` 元素。这样不仅能够提高解析效率,还能减少内存占用。本文将详细介绍如何使用 Pull 解析方法来提取 `` 标签的内容,并提供一个示例代码,帮助开发者快速解决问题。 ... [详细]
  • 在Java Web服务开发中,Apache CXF 和 Axis2 是两个广泛使用的框架。CXF 由于其与 Spring 框架的无缝集成能力,以及更简便的部署方式,成为了许多开发者的首选。本文将详细介绍如何使用 CXF 框架进行 Web 服务的开发,包括环境搭建、服务发布和客户端调用等关键步骤,为开发者提供一个全面的实践指南。 ... [详细]
  • 本文深入探讨了Ajax的工作机制及其在现代Web开发中的应用。Ajax作为一种异步通信技术,改变了传统的客户端与服务器直接交互的模式。通过引入Ajax,客户端与服务器之间的通信变得更加高效和灵活。文章详细分析了Ajax的核心原理,包括XMLHttpRequest对象的使用、数据传输格式(如JSON和XML)以及事件处理机制。此外,还介绍了Ajax在提升用户体验、实现动态页面更新等方面的具体应用,并讨论了其在当前Web开发中的重要性和未来发展趋势。 ... [详细]
  • 作为软件工程专业的学生,我深知课堂上教师讲解速度之快,很多时候需要课后自行消化和巩固。因此,撰写这篇Java Web开发入门教程,旨在帮助初学者更好地理解和掌握基础知识。通过详细记录学习过程,希望能为更多像我一样在基础方面还有待提升的学员提供有益的参考。 ... [详细]
  • 在对WordPress Duplicator插件0.4.4版本的安全评估中,发现其存在跨站脚本(XSS)攻击漏洞。此漏洞可能被利用进行恶意操作,建议用户及时更新至最新版本以确保系统安全。测试方法仅限于安全研究和教学目的,使用时需自行承担风险。漏洞编号:HTB23162。 ... [详细]
  • 深入解析Android 4.4中的Fence机制及其应用
    在Android 4.4中,Fence机制是处理缓冲区交换和同步问题的关键技术。该机制广泛应用于生产者-消费者模式中,确保了不同组件之间高效、安全的数据传输。通过深入解析Fence机制的工作原理和应用场景,本文探讨了其在系统性能优化和资源管理中的重要作用。 ... [详细]
  • Python 伦理黑客技术:深入探讨后门攻击(第三部分)
    在《Python 伦理黑客技术:深入探讨后门攻击(第三部分)》中,作者详细分析了后门攻击中的Socket问题。由于TCP协议基于流,难以确定消息批次的结束点,这给后门攻击的实现带来了挑战。为了解决这一问题,文章提出了一系列有效的技术方案,包括使用特定的分隔符和长度前缀,以确保数据包的准确传输和解析。这些方法不仅提高了攻击的隐蔽性和可靠性,还为安全研究人员提供了宝贵的参考。 ... [详细]
  • 优化后的标题:深入探讨网关安全:将微服务升级为OAuth2资源服务器的最佳实践
    本文深入探讨了如何将微服务升级为OAuth2资源服务器,以订单服务为例,详细介绍了在POM文件中添加 `spring-cloud-starter-oauth2` 依赖,并配置Spring Security以实现对微服务的保护。通过这一过程,不仅增强了系统的安全性,还提高了资源访问的可控性和灵活性。文章还讨论了最佳实践,包括如何配置OAuth2客户端和资源服务器,以及如何处理常见的安全问题和错误。 ... [详细]
  • Keepalived 提供了多种强大且灵活的后端健康检查机制,包括 HTTP_GET、SSL_GET、TCP_CHECK、SMTP_CHECK 和 MISC_CHECK 等多种检测方法。这些健康检查功能确保了高可用性环境中的服务稳定性和可靠性。通过合理配置这些检查方式,可以有效监测后端服务器的状态,及时发现并处理故障,从而提高系统的整体性能和可用性。 ... [详细]
author-avatar
手浪用户2702933404
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有