`

GridView的自定义分页,单选、多选、排序、自增列的简单应用

阅读更多
关于VS2005中GridView的自定义分页,单选、多选、排序、自增列的简单应用。
    多选时,只有全部选中时“多选”才选中。

    图片效果:[见附件]
     简单示例,代码如下,
   fenpage.aspx的代码
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="fenpage.aspx.cs" Inherits="gridview_fenpage" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>

    <script language="javascript" type="text/javascript">    
    // 判断多选是否与选中项(没有选中的返回false)
    function slcNo_click()
    {
        if (document.form1.checkboxname.length)
        {
            for (var i=0;i<document.form1.checkboxname.length;i++)
            {
                if(document.form1.checkboxname[i].checked)
                {
                    return true;
                }
            }
        }
        else
        {
            if(document.form1.checkboxname.checked)
            {
                return true;
            }
        }
        alert("请选择后再操作!");
        return false;
    }
    
    // 鼠标经过改变行的颜色
    if (!objbeforeItem)
    {
        var objbeforeItem=null;
        var objbeforeItembackgroundColor=null;
    }    
    function ItemOver(obj)
    {
        if(objbeforeItem)
        {
            objbeforeItem.style.backgroundColor = objbeforeItembackgroundColor;
        }
        objbeforeItembackgroundColor = obj.style.backgroundColor;
        objbeforeItem = obj;
        obj.style.backgroundColor = "#B9D1F3";     
    }
    //        
 
    // 多选的全选与取消
    function checkJs(boolvalue)
    {
        if(document.all.checkboxname.length>1)
        {
            for(var i=0;i<document.all.checkboxname.length;i++)
            {
                document.all.checkboxname[i].checked = boolvalue;            
            }
        }
        else
            document.all.checkboxname.checked = boolvalue;
    }
    //
    
    // 只有全部选中时“全选”选中
    function SingleCheckJs()
    {
        var flag1=false;
        var flag2=false;
        
        if (document.form1.checkboxname.length)
        {
            for (var i=0;i<document.form1.checkboxname.length;i++)
            {
                if(document.form1.checkboxname[i].checked)
                    flag1 = true;
                else
                    flag2 = true;
            }
        }
        else
        {
            if(document.form1.checkboxname.checked)
                flag1 = true;
            else
                flag2 = true;
        }
        
        if(flag1==true&&flag2==false)
            document.getElementById("chk").checked = true;
        else
            document.getElementById("chk").checked = false;
    }
    //
    </script>
</head>
<body>
    <form id="form1" runat="server">
        <div>
            <table cellpadding="0" cellspacing="0" border="0" width="80%" style="font-size: 11px">
                <tr>
                    <td align="center">
                        <asp:GridView ID="GridView1" runat="server" Width="100%" CellPadding="4" ForeColor="#333333"
                            AutoGenerateColumns="False" AllowPaging="True" PageSize="12" BorderColor="Silver"
                            BorderStyle="Solid" BorderWidth="1px" OnRowDataBound="GridView1_RowDataBound"
                            ShowFooter="True" EmptyDataText="没有数据记录!!" AllowSorting="True" OnSorting="GridView1_Sorting">
                            <Columns>
                                <asp:BoundField HeaderText="编号" DataField="id" Visible="False" />
                                <asp:TemplateField HeaderText="&lt;input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);'  /&gt;全选" FooterText="全选">
                                    <ItemTemplate>
                                        <input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' onclick='SingleCheckJs();' />
                                    </ItemTemplate>
                                </asp:TemplateField>
                                <asp:TemplateField HeaderText="单选" FooterText="单选">
                                    <ItemTemplate>
                                        <input type="radio" id="RadioName" name="RadioName" value='<%# Eval("id")%>' />
                                    </ItemTemplate>
                                </asp:TemplateField>
                                <asp:TemplateField HeaderText="自增列" FooterText="自增列">
                                    <ItemTemplate>
                                        <%# (Container.DataItemIndex+1).ToString()%>
                                    </ItemTemplate>
                                </asp:TemplateField>
                                <asp:BoundField HeaderText="姓名" FooterText="姓名" DataField="name" SortExpression="name" />
                                <asp:BoundField HeaderText="身份证号" FooterText="身份证号" DataField="card" SortExpression="card" />
                                <asp:BoundField HeaderText="价格" FooterText="价格" DataField="price" DataFormatString="{0:¥#,##0.00}"
                                    HtmlEncode="False" SortExpression="price" />
                                <asp:BoundField HeaderText="数字" FooterText="数字" DataField="price" DataFormatString="{0:0.00}"
                                    HtmlEncode="False" SortExpression="price" />
                                <asp:BoundField HeaderText="建立时间" FooterText="建立时间" DataField="createdate" DataFormatString="{0:yyyy年MM月dd日 hh时mm分ss秒}"
                                    HtmlEncode="False" SortExpression="createdate" />
                            </Columns>
                            <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
                            <EditRowStyle BackColor="#999999" />
                            <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
                            <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
                            <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
                            <PagerSettings Visible="False" />
                            <FooterStyle Font-Bold="True" />
                            <HeaderStyle Font-Bold="False" Font-Italic="False" />
                        </asp:GridView>
                    </td>
                </tr>
                <tr>
                    <td align="center" style="height: 25px">
                        <asp:LinkButton ID="btnFirst" CommandArgument="first" OnClick="PagerButtonClick"
                            runat="server">首 页</asp:LinkButton>
                        <asp:LinkButton ID="btnPrev" CommandArgument="prev" OnClick="PagerButtonClick" runat="server">上一页</asp:LinkButton>
                        <asp:LinkButton ID="btnNext" CommandArgument="next" OnClick="PagerButtonClick" runat="server">下一页</asp:LinkButton>
                        <asp:LinkButton ID="btnLast" CommandArgument="last" OnClick="PagerButtonClick" runat="server">尾 页</asp:LinkButton>
                        <asp:Label ID="LblCurrentIndex" runat="server"></asp:Label>
                        <asp:Label ID="LblPageCount" runat="server"></asp:Label>
                        <asp:Label ID="LblRecordCount" runat="server"></asp:Label></td>
                </tr>
                <tr>
                    <td>
                        <asp:Button ID="Button2" runat="server" Text="checkbox得到选择的行" OnClick="Button2_Click">
                        </asp:Button>
                        <asp:Button ID="Button1" runat="server" Text="radio得到选择的行" OnClick="Button1_Click"></asp:Button>
                    </td>
                </tr>
            </table>
        </div>
    </form>
</body>
</html>


fenpage.aspx.cs的代码

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;

public partial class gridview_fenpage : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        Button2.Attributes["onclick"] = "return slcNo_click();";
        GridViewBind("");
    }

    private void GridViewBind(string Sqlsort)
    {
        string connStr = ConfigurationManager.ConnectionStrings["ConnString1"].ConnectionString;
        string SqlStr = "SELECT * FROM test01 where id<1000" + Sqlsort;
        DataSet ds = new DataSet();
        
        try
        {
            SqlConnection conn = new SqlConnection(connStr);
            if (conn.State.ToString() == "Closed") conn.Open();

            SqlDataAdapter da = new SqlDataAdapter(SqlStr, conn);
            da.Fill(ds, "test01");            
            if (conn.State.ToString() == "Open") conn.Close();

            GridView1.DataSource = ds.Tables[0].DefaultView;
            GridView1.DataBind();

            LblCurrentIndex.Text = "第 " + (GridView1.PageIndex + 1).ToString() + " 页";
            LblPageCount.Text = "共 " + GridView1 .PageCount.ToString()+ " 页";
            LblRecordCount.Text = "总共 "+ds.Tables[0].Rows.Count.ToString()+" 条";
            if (ds.Tables[0].Rows.Count == 0)
            {
                btnFirst.Visible = false;
                btnPrev.Visible = false;
                btnNext.Visible = false;
                btnLast.Visible = false;

                LblCurrentIndex.Visible = false;
                LblPageCount.Visible = false;
                LblRecordCount.Visible = false;
            }
            else if (GridView1.PageCount == 1)
            {
                btnFirst.Visible = false;
                btnPrev.Visible = false;
                btnNext.Visible = false;
                btnLast.Visible = false;
            }

            // 计算生成分页页码,分别为:"首 页" "上一页" "下一页" "尾 页"
            btnFirst.CommandName = "1";
            btnPrev.CommandName = (GridView1.PageIndex == 0 ? "1" : GridView1.PageIndex.ToString());

            btnNext.CommandName = (GridView1.PageCount == 1 ? GridView1.PageCount.ToString() : (GridView1.PageIndex + 2).ToString());
            btnLast.CommandName = GridView1.PageCount.ToString();
            //
        }
        catch(Exception ex)
        {
            Response.Write("数据库错误,错误原因:"+ex.Message);
            Response.End();
        }
    }
    protected void PagerButtonClick(object sender, EventArgs e)
    {
        GridView1.PageIndex = Convert.ToInt32(((LinkButton)sender).CommandName)-1;
        GridViewBind("");        
    }

    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        e.Row.Attributes["onmouseover"] = "ItemOver(this)";
    }

    protected void Button2_Click(object sender, EventArgs e)
    {
        string str=""; 
        string []ckb=null; 

        str=Request.Form.Get("checkboxname"); 
        ckb=str.Split(new char[]{','}); 

        Response.Write("直接在页面中得到的值为:"+str+"<br>"); 

        Response.Write("处理后存放在数组中,如下:<br>"); 
        for(int i=0;i<ckb.Length;i++) 
        { 
            Response.Write("ckb["+i+"]的值为:"+ckb[i]+"<br>"); 
        } 
    }
    protected void Button1_Click(object sender, EventArgs e)
    {
        Response.Write(Request.Form.Get("RadioName"));
    }
    protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
    {
        string sql = "";

        if (ViewState["SortDirection"] == null || ViewState["SortDirection"].ToString().CompareTo("") == 0)
        {
            ViewState["SortDirection"] = " desc";
        }
        else
            ViewState["SortDirection"] = "";

        sql = " order by " + e.SortExpression + ViewState["SortDirection"];
        
        GridViewBind(sql);
    }
}

  • 大小: 176.5 KB
分享到:
评论

相关推荐

    最简单的GridView自定义分页

    在ASP.NET开发中,GridView控件是用于展示数据表格的常用工具,它提供了方便的数据绑定和...通过阅读《最简单的GridView自定义分页.doc》文档,你将获得更详细的操作指南和示例代码,帮助你更好地理解和应用这个功能。

    asp.net中的GridView自定义分页及排序代码

    本文将详细介绍如何在ASP.NET中实现GridView的自定义分页及排序功能,以帮助开发者提高用户体验并优化性能。 首先,我们要了解默认的GridView分页和排序机制。默认情况下,GridView会加载所有数据到内存中,然后...

    gridview实现自定义分页

    然而,标准的GridView控件默认的分页功能可能无法满足所有用户的需求,这时我们需要自定义分页来提供更加灵活和个性化的用户体验。本文将深入探讨如何在GridView中实现自定义分页,以及这一过程中的关键知识点。 ...

    GridView自定义分页及可拖动改变列宽代码

    GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 ...

    GridView自定义分页可拖动列宽

    本篇将深入探讨如何实现GridView的自定义分页功能以及允许用户通过拖动列宽来调整列的大小。 1. **自定义分页**: 自定义分页是为了提高应用性能,减少不必要的数据查询,只加载当前页所需的数据。默认情况下,...

    ObjectDataSource和Gridview自定义分页

    在自定义分页方面,GridView默认提供简单的分页功能,但可能无法满足所有复杂需求,例如每页显示特定数量的记录或根据特定条件过滤数据。此时,我们需要自定义分页逻辑。在GridView中,可以通过设置`AllowPaging`...

    C#_winform_GridView_CheckBox_多选_全选

    GridView是.NET Framework中的System.Windows.Forms.DataGridView类,它提供了丰富的功能,如排序、过滤、分页等。在设计阶段,可以通过Visual Studio的工具箱将DataGridView拖放到窗体上,然后通过代码或设计器设置...

    asp.net gridview自定义分页

    此处自定义分页是在需要时才加载当页数据。 示例中包含完整的Sql数据库访问类(考虑到了存储过程的使用),也可以适应不同的数据库,简单的修改代码即可使用。 示例逻辑层采用存储过程访问数据库,加快访问速度。...

    自定义GridView分页模板

    在上述文档中,主要讨论了如何自定义GridView的分页模板,以提供更个性化的用户体验。 首先,GridView控件的分页功能是通过设置`AllowPaging`属性为`True`来启用的。`PageSize`属性用来定义每一页显示的数据行数。...

    GridView自定义分页及可拖动改变列宽源码

    在.NET开发环境中,GridView是一种常用的数据显示控件,用于展示数据集中的信息,通常与数据库连接,用于数据的显示、编辑和排序。然而,系统默认的GridView功能有限,不能满足所有需求,例如,它没有内置的自定义...

    .net的GRIDVIEW自定义分页功能

    找了三天才找到合适会用的gridview自定义分页功能,之前找了n多种方法,没一个能用的,直到现在这个才真正的在自己的网页上用上。现在上传上来给有需要的朋友一个方便,2分的资源分只是想借朋友的一点力积点分方便...

    Android三级目录、ListView单选/GridView单选、ListView多选/GridView多选

    综上所述,实现Android中的ListView和GridView的单选或多选功能,需要理解Adapter的工作原理,熟悉RadioGroup和CheckBox的使用,以及如何自定义View样式。同时,通过监听事件和更新视图状态,我们可以为用户提供直观...

    GridView自定义分页的四种存储过程

    为了提高效率,开发者通常会选择自定义分页,本文将探讨四种使用存储过程实现GridView自定义分页的方法。 首先,我们来理解为什么不应依赖GridView的默认分页。默认分页是通过数据源控件(如SqlDataSource)来实现...

    自定义单选,多选对话框(android)

    总的来说,自定义单选和多选对话框是Android开发中常见的需求,掌握这一技巧对提升应用的用户体验至关重要。通过学习和实践,开发者不仅可以创建出美观且功能丰富的对话框,还能进一步提升自己的编程技能。

    在GridView中实现单选或多选功能

    这篇博客“在GridView中实现单选或多选功能”主要讲解了如何在GridView中添加单选和多选功能,这对于提升用户体验和增加应用交互性至关重要。 1. GridView基础: GridView继承自AbsListView,通过Adapter来填充...

    GridView自定义分页并集成列可拖动功能控件

    在本案例中,我们探讨的是一个名为“GridViewPageable”的自定义控件,它扩展了标准的GridView功能,增加了分页和列可拖动的特性。这种增强使得开发者在构建数据密集型应用时能更方便地调整布局,提高用户体验。 ...

    asp.net中的GridView自定义分页及可拖动改变列宽代码

    总的来说,ASP.NET中的GridView自定义分页和可拖动改变列宽是提高用户体验的重要手段。通过结合C#服务器端代码、JavaScript客户端代码以及数据库操作,我们可以为用户提供更加灵活和个性化的数据查看体验。

    asp.net中的GridView自定义分页及改变列宽代码

    本主题将深入探讨如何实现GridView的自定义分页功能以及动态改变列宽的代码实现。 首先,让我们来理解GridView的基本用法。GridView是ASP.NET Web Forms中的一种服务器控件,它能够自动绑定到数据源并生成表格来...

    批量上传图片+lightbox+图片评论+gridview自定义分页控件

    本项目"批量上传图片+lightbox+图片评论+gridview自定义分页控件"正是为了解决这一需求而设计的。以下将详细解释这个系统的关键组成部分及其技术要点。 1. 批量上传图片: 批量上传功能允许用户一次性上传多张图片...

Global site tag (gtag.js) - Google Analytics