- 浏览: 37929 次
- 性别:
- 来自: 沈阳
文章分类
最新评论
数据库中表的生成代码:
CREATE TABLE [dbo].[test01] (
[id] [decimal](18, 0) IDENTITY (1, 1) NOT NULL ,
[name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[card] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[createdate] [datetime] NULL
) ON [PRIMARY]
GO
ALTER TABLE [dbo].[test01] ADD
CONSTRAINT [DF_test01_createdate] DEFAULT (getdate()) FOR [createdate],
CONSTRAINT [PK_test01] PRIMARY KEY CLUSTERED
(
[id]
) ON [PRIMARY]
GO
fenpage.aspx页面
fenpage.aspx.cs页
CREATE TABLE [dbo].[test01] (
[id] [decimal](18, 0) IDENTITY (1, 1) NOT NULL ,
[name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[card] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
[createdate] [datetime] NULL
) ON [PRIMARY]
GO
ALTER TABLE [dbo].[test01] ADD
CONSTRAINT [DF_test01_createdate] DEFAULT (getdate()) FOR [createdate],
CONSTRAINT [PK_test01] PRIMARY KEY CLUSTERED
(
[id]
) ON [PRIMARY]
GO
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="5" BorderColor="Silver" BorderStyle="Solid" BorderWidth="1px" OnRowDataBound="GridView1_RowDataBound" EmptyDataText="没有数据记录!!" AllowSorting="True"> <Columns> <asp:BoundField HeaderText="编号" DataField="id" Visible="False" /> <asp:TemplateField HeaderText="<input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);' />全选" 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="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 style="height: 25px"> <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> <asp:GridView ID="GridView2" runat="server" AllowPaging="True" AutoGenerateColumns="False" BorderStyle="Solid"> </asp:GridView> </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(""); } public 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); } }
发表评论
-
asp.net不用FileUpload上传文件
2010-08-18 22:07 3905WebClient wc = new WebClient( ... -
asp.net 加密及解密 url
2009-06-19 12:37 2339using System; using System.D ... -
设计模式初学者系列-开篇以及抽象工厂模式
2009-05-29 10:12 1166一、设计模式定义、来 ... -
在ASP.NET中动态加载内容(用户控件和模板)
2009-05-29 09:54 2328在ASP.NET中动态加载内容(用户控件和模板) 要点: ... -
ASP.NET中移除全部缓存
2009-05-27 14:35 1005IDictionaryEnumerator CacheEn ...
相关推荐
"下一页" /> 末页" /> </td> </tr> ...总之,自定义GridView分页模板允许开发者更好地控制数据展示的方式,提高用户体验,并根据项目需求进行定制化设计。通过理解并运用上述知识,可以创建出既美观又实用的分页界面。
而“自定义Gridview分页”是指在使用Gridview时,根据具体需求对默认的分页功能进行定制,以满足更加复杂或个性化的用户交互体验。在本案例中,我们关注的是如何结合`Ajax`技术来实现这一功能。 `Ajax`...
然而,标准的GridView控件默认的分页功能可能无法满足所有用户的需求,这时我们需要自定义分页来提供更加灵活和个性化的用户体验。本文将深入探讨如何在GridView中实现自定义分页,以及这一过程中的关键知识点。 ...
总结,实现“最简单的GridView自定义分页”主要是通过设置GridView的分页属性,配合数据源查询的分页功能,以及处理分页事件来完成。在实际项目中,可以进一步优化分页的性能和交互效果,以适应不同的需求和场景。...
2. **分页功能**: 分页是大型数据集显示的关键,可提高网页加载速度并改善用户体验。在自定义GridView中,可以添加分页逻辑,例如设置每页显示的记录数,实现前后翻页,以及总页数的计算。分页信息通常存储在控件...
本篇文章将详细讲解如何在Android中利用GridView实现分页加载功能。 首先,理解GridView的基本概念。GridView是ListView的一种变体,它按照指定的列数来排列子视图。默认情况下,GridView会一次性加载所有数据,这...
综上所述,通过自定义GridView的分页样式并利用CSS,我们可以为用户提供一套既美观又实用的分页体验。这不仅提升了网页的整体视觉效果,也优化了数据加载的效率。在实际开发中,不断尝试和优化,你会发现更多可能,...
1. item布局:自定义GridView的每一项布局,可以使用XML文件定义,例如设置每个单元格的大小、边距、内边距以及内容的展示方式(图片、文字等)。 2. 适配器扩展:继承BaseAdapter,重写其中的`getCount()`、`...
数据量很大时,使用gridview内置的分页功能,页面加载会非常慢。此处自定义分页是在需要时才加载当页数据。 示例中包含完整的Sql数据库访问类(考虑到了存储过程的使用),也可以适应不同的数据库,简单的修改代码...
总结来说,自定义控件gridview分页导出涉及到以下几个关键知识点: 1. GridView控件的使用:绑定数据源,设置分页属性,处理分页事件。 2. 自定义控件的创建:继承现有控件,添加新的功能和属性。 3. 数据导出:根据...
首先,我们要了解默认的GridView分页和排序机制。默认情况下,GridView会加载所有数据到内存中,然后根据用户的选择进行分页和排序,这可能导致性能问题,尤其是处理大量数据时。因此,自定义分页和排序是必要的,它...
**二、ASPxGridView分页功能** 1. **基本分页**: 设置`AllowPaging`为`true`启用分页功能。默认情况下,ASPxGridView会显示每页的页码,用户可以通过点击页码或使用导航按钮(上一页、下一页)来切换页面。 2. **...
在我们的自定义GridView控件中,表现层将负责展示数据,业务逻辑层处理业务规则,而数据访问层则用于与数据库交互。 自定义GridView控件通常涉及以下步骤: 1. **创建自定义控件**:在Visual Studio中,我们可以...
本主题将深入探讨如何在三层架构中实现ASP.NET GridView的分页功能。 三层架构通常包括表现层(UI)、业务逻辑层(BLL)和数据访问层(DAL)。在这样的架构下,业务逻辑和数据处理与用户界面分离,提高了代码的可...
找了三天才找到合适会用的gridview自定义分页功能,之前找了n多种方法,没一个能用的,直到现在这个才真正的在自己的网页上用上。现在上传上来给有需要的朋友一个方便,2分的资源分只是想借朋友的一点力积点分方便...
自定义GridView控件是为了满足更复杂的业务需求,例如分页和多选功能,这在标准GridView控件中可能需要额外的配置或扩展才能实现。在这个自定义实现中,`GridViewPageable.cs`文件很可能是包含这个自定义控件逻辑的...
GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 GridView自定义分页及可拖动改变列宽代码 ...
6. **用户交互**:可自定义GridView的分页栏,例如,显示总页数,或者提供快速跳转到指定页的功能。 通过这样的方式,我们实现了利用存储过程和GridView分页用户控件的强大组合,使得在大量数据处理时既能保证性能...
在自定义分页方面,GridView默认提供简单的分页功能,但可能无法满足所有复杂需求,例如每页显示特定数量的记录或根据特定条件过滤数据。此时,我们需要自定义分页逻辑。在GridView中,可以通过设置`AllowPaging`...
本资源将介绍如何为GridView实现自定义分页功能,这是一项关键的技术,能够帮助开发者优化数据呈现,避免一次性加载所有数据导致的性能问题。 在默认情况下,GridView控件提供了内置的分页功能,但往往无法满足特定...