<script src="http://www.yesky.com/TLimages/head/y_newcontenthead_0608.js" type="text/javascript"></script>
Asp.net 2.0中新增的gridview控件,是十分强大的数据展示控件,在前面的系列文章里,分别展示了其中很多的基本用法和技巧(详见<<
ASP.NET 2.0中Gridview控件高级技巧>>、<<
ASP.NET2.0利用Gridview实现主从关系>>)。在本文中,将继续探讨有关的技巧。
一、Gridview中的内容导出到Excel
在日常工作中,经常要将gridview中的内容导出到excel报表中去,在asp.net 2.0中,同样可以很方便地实现将整个gridview中的内容导出到excel报表中去,下面介绍其具体做法:
首先,建立基本的页面default.aspx
在default.aspx.cs中,写入如下代码:
在上面的代码中,我们首先将gridview绑定到指定的数据源中,然后在button1的按钮(用来做导出到EXCEL的)的事件中,写入相关的代码。这里使用Response.AddHeader("content-disposition","attachment;filename=exporttoexcel.xls");中的filename来指定将要导出的excel的文件名,这里是exporttoexcel.xls。要注意的是,由于gridview的内容可能是分页显示的,因此,这里在每次导出excel时,先将gridview的allowpaging属性设置为false,然后通过页面流的方式导出当前页的gridview到excel中,最后再重新设置其allowpaging属性。另外要注意的是,要写一个空的VerifyRenderingInServerForm方法(必须写),以确认在运行时为指定的ASP.NET 服务器控件呈现HtmlForm 控件。
二、访问gridview中的各类控件
在gridview中,经常要访问其中的各类控件,比如dropdownlist,radiobutton,checkbox等,下面归纳下在gridview中访问各类控件的方法。
首先看下如何在gridview中访问dropdownlist控件。假设在一个gridviw中,展现的每条记录中都需要供用户用下拉选择的方式选择dropdownlist控件中的内容,则可以使用如下代码,当用户选择好gridview中的dropdownlist控件的选项后,点击按钮,则系统打印出用户到底选择了哪些dropdownlist控件,并输出它们的值。
上面的代码首先将数据库中tblphone表的数据以dataset的形式返回。然后在页面的itemtemplate中,如下设计:
这里注意dropdownlist控件的datasource属性绑定了刚才返回的dataset(调用了populatedropdownlist()方法),并要注意设置好datatextfield和datavaluefield属性。
然后,在button的事件中,写入以下代码:
这里,我们用循环,来获得每一行的dropdownlist控件的值,并且将值添加到字符串中最后输出。
接着,我们来看下如何访问gridview控件中的checkbox控件。经常在gridview控件中,需要给用户多项选择的功能,这个时候就需要使用checkbox控件。首先我们建立一个模版列,其中有checkbox如下:
为了示意性地讲解如何得到用户选择的checkbox,可以增加一个按钮,当用户选择gridview中的选项后,点该按钮,则可以输出用户选了哪些选项,在按钮的CLICK事件中写入如下代码:
接下来,我们添加一个全选的选择框,当用户选择该框时,可以全部选择gridview中的checkbox.首先我们在headtemplate中如下设计:
javascript部分的代码如下所示:
<script language="JavaScript" type="text/javascript">
</script>
<script language="javascript" type="text/javascript">
</script> <script language="JavaScript" src="http://comments.yesky.com/articlereplies/6/4483/2329483.js" charset="gb2312" type="text/javascript"></script>
<script language="JavaScript" type="text/javascript">
</script>
<script src="http://www.yesky.com/TLimages/qljs/contentjs.js" type="text/javascript"></script>
<script language="JavaScript" type="text/javascript"> </script> <script language="JavaScript" src="http://www.yesky.com/TLimages/projs/specdealer/-1_specdealer.js" charset="gb2312" type="text/javascript"></script>
ASP.NET2.0中Gridview中数据操作技巧
Asp.net 2.0中新增的gridview控件,是十分强大的数据展示控件
一、Gridview中的内容导出到Excel
在日常工作中,经常要将gridview中的内容导出到excel报表中去,在asp.net 2.0中,同样可以很方便地实现将整个gridview中的内容导出到excel报表中去,下面介绍其具体做法:
首先,建立基本的页面default.aspx
<form id="form1" runat="server"> <div> <asp:GridView ID="GridView1" runat="server"> </asp:GridView> </div> <br/> <asp:Button ID="BtnExport" runat="server" OnClick="BtnExport_Click" Text="Export to Excel" /> </form> |
在default.aspx.cs中,写入如下代码:
protected void Page_Load(object sender, EventArgs e) { if (!Page.IsPostBack) { BindData(); } } private void BindData() { string query = "SELECT * FROM customers"; SqlConnection myConnection = new SqlConnection(ConnectionString); SqlDataAdapter ad = new SqlDataAdapter(query, myConnection); DataSet ds = new DataSet(); ad.Fill(ds, "customers"); GridView1.DataSource = ds; GridView1.DataBind(); } public override void VerifyRenderingInServerForm(Control control) { // Confirms that an HtmlForm control is rendered for } protected void Button1_Click(object sender, EventArgs e) { Response.Clear(); Response.AddHeader("content-disposition","attachment;filename=FileName.xls"); Response.Charset = "gb2312"; Response.ContentType = "application/vnd.xls"; System.IO.StringWriter stringWrite = new System.IO.StringWriter(); System.Web.UI.HtmlTextWriter htmlWrite =new HtmlTextWriter(stringWrite); GridView1.AllowPaging = false; BindData(); GridView1.RenderControl(htmlWrite); Response.Write(stringWrite.ToString()); Response.End(); GridView1.AllowPaging = true; BindData(); } protected void paging(object sender,GridViewPageEventArgs e) { GridView1.PageIndex = e.NewPageIndex; BindData(); } |
在上面的代码中,我们首先将gridview绑定到指定的数据源中,然后在button1的按钮(用来做导出到EXCEL的)的事件中,写入相关的代码。这里使用Response.AddHeader("content-disposition","attachment;filename=exporttoexcel.xls");中的filename来指定将要导出的excel的文件名,这里是exporttoexcel.xls。要注意的是,由于gridview的内容可能是分页显示的,因此,这里在每次导出excel时,先将gridview的allowpaging属性设置为false,然后通过页面流的方式导出当前页的gridview到excel中,最后再重新设置其allowpaging属性。另外要注意的是,要写一个空的VerifyRenderingInServerForm方法(必须写),以确认在运行时为指定的ASP.NET 服务器控件呈现HtmlForm 控件。
二、访问gridview中的各类控件
在gridview中,经常要访问其中的各类控件,比如dropdownlist,radiobutton,checkbox等,下面归纳下在gridview中访问各类控件的方法。
首先看下如何在gridview中访问dropdownlist控件。假设在一个gridviw中,展现的每条记录中都需要供用户用下拉选择的方式选择dropdownlist控件中的内容,则可以使用如下代码,当用户选择好gridview中的dropdownlist控件的选项后,点击按钮,则系统打印出用户到底选择了哪些dropdownlist控件,并输出它们的值。
public DataSet PopulateDropDownList() { SqlConnection myConnection =new SqlConnection(ConfigurationManager.ConnectionStrings["MyDatabase"].ConnectionString); SqlDataAdapter ad = new SqlDataAdapter("SELECT * FROM tblPhone", myConnection); DataSet ds = new DataSet(); ad.Fill(ds, "tblPhone"); return ds; } |
上面的代码首先将数据库中tblphone表的数据以dataset的形式返回。然后在页面的itemtemplate中,如下设计:
<ItemTemplate> <asp:DropDownList ID="DropDownList1" runat="server" DataSource="<%# PopulateDropDownList() %>" DataTextField="Phone" DataValueField = "PhoneID"> </asp:DropDownList> </ItemTemplate> |
这里注意dropdownlist控件的datasource属性绑定了刚才返回的dataset(调用了populatedropdownlist()方法),并要注意设置好datatextfield和datavaluefield属性。
然后,在button的事件中,写入以下代码:
protected void Button2_Click(object sender, EventArgs e) { StringBuilder str = new StringBuilder(); foreach (GridViewRow gvr in GridView1.Rows) { string selectedText = ((DropDownList)gvr.FindControl("DropDownList1")).SelectedItem.Text; str.Append(selectedText); } Response.Write(str.ToString()); } |
这里,我们用循环,来获得每一行的dropdownlist控件的值,并且将值添加到字符串中最后输出。
接着,我们来看下如何访问gridview控件中的checkbox控件。经常在gridview控件中,需要给用户多项选择的功能,这个时候就需要使用checkbox控件。首先我们建立一个模版列,其中有checkbox如下:
<asp:GridView ID="GridView1" runat="server" AllowPaging="True" AllowSorting="True" AutoGenerateColumns="False" DataKeyNames="PersonID" DataSourceID="mySource" Width="366px" CellPadding="4" ForeColor="#333333" GridLines="None"> <Columns> <asp:CommandField ShowSelectButton="True" /> <asp:BoundField DataField="PersonID" HeaderText="PersonID" InsertVisible="False" ReadOnly="True" SortExpression="PersonID" /> <asp:BoundField DataField="Name" HeaderText="Name" SortExpression="Name" /> <asp:TemplateField HeaderText="Select"> <ItemTemplate> <asp:CheckBox ID="chkSelect" runat="server" /> </ItemTemplate> <HeaderTemplate> </HeaderTemplate> </asp:TemplateField> </Columns> </asp:GridView> |
为了示意性地讲解如何得到用户选择的checkbox,可以增加一个按钮,当用户选择gridview中的选项后,点该按钮,则可以输出用户选了哪些选项,在按钮的CLICK事件中写入如下代码:
for (int i = 0; i < GridView1.Rows.Count; i++) { GridViewRow row = GridView1.Rows[i]; bool isChecked = ((CheckBox) row.FindControl("chkSelect")).Checked; if (isChecked) { str.Append(GridView1.Rows[i].Cells[2].Text); } } Response.Write(str.ToString()); |
接下来,我们添加一个全选的选择框,当用户选择该框时,可以全部选择gridview中的checkbox.首先我们在headtemplate中如下设计:
<HeaderTemplate> <input id="chkAll" οnclick="javascript:SelectAllCheckboxes(this);" runat="server" type="checkbox" /> </HeaderTemplate> |
javascript部分的代码如下所示:
<script language=javascript> function SelectAllCheckboxes(spanChk){ var oItem = spanChk.children; var theBox=(spanChk.type=="checkbox")?spanChk:spanChk.children.item[0]; xState=theBox.checked; elm=theBox.form.elements; for(i=0;i<elm.length;i++) if(elm[i].type=="checkbox" && elm[i].id!=theBox.id) { if(elm[i].checked!=xState) elm[i].click(); } } </script> |
|
· | 知本家有奖活动进行中 | · | 超低话费只需0.12元/分! | · | 戴尔网站 大礼不断 |
· | 上网买戴尔,超值不超支! | · | 金山毒霸高速下载 终身免费 | · | '充300送300'继续升温... |
· | 免费下载最新版杀毒软件 | · | 上网买戴尔,得免费升级大礼 | · | Excel服务器学习下载 |
相关文章
最新更新
编辑新作
热点文章
- C#+ASP.NET开发基于Web的RSS阅读器(2006-02-10 09:43)
- ASP.NET2.0中使用数据源控件之基础知识(2006-02-14 09:23)
- ASP.NET2.0中使用数据源控件之参数(2006-02-16 09:31)
- ASP.NET2.0中数据源控件之异步数据访问(2006-02-17 14:48)
- ASP.NET编程入门随想之宽容(2006-02-20 08:24)
- ASP.NET2.0导航功能之配置会员和角色(2006-03-01 15:13)
- 在ASP.NET程序中实现语音合成(2006-03-01 15:48)
- ASP.NET 2.0 想说爱你不容易(2006-03-08 16:39)
- ASP.NET1.0升级ASP.NET2.0的问题总结(2006-03-10 08:46)
- ASP.NET中实现大结果集分页研讨(2006-03-13 09:33)
- ASP.NET 2.0中使用multiview控件(2006-03-15 16:35)
- ASP.NET 2.0中实现跨页面提交(2006-03-16 09:13)
- 创新源于理解 轻松打造自己的AJAX框架(2006-03-16 15:01)
- 用ASP.NET设计高效邮件列表(2006-03-17 08:31)
- ASP.NET 2.0中使用HiddenField控件(2006-03-17 08:36)
- 揭开ASP.NET中Cookie编程的奥秘(2006-03-17 08:47)
- ASP.NET程序中实现校验码图像生成(2006-03-17 09:47)
- 在ASP.NET中防止注入攻击(2006-03-31 17:05)
- ASP.NET页面中标题单点解决方案(2006-04-04 08:36)
- 软件周刊_天极Yesky(专题)
最新热图
<script language="JavaScript" src="http://pic.yesky.com/js/wenzhang.js" type="text/javascript"></script>
天极无线
- ASP.NET(80)
<script type="text/javascript"> function copyToClipBoard() { var clipBoardContent=document.title; clipBoardContent+='/r/n' + document.location.href; window.clipboardData.setData("Text",clipBoardContent); alert("复制成功,请粘贴到你的QQ/MSN上推荐给你的好友!/r/n/r/n内容如下:/r/n" + clipBoardContent); } </script>
复制链接
相关关键字
- ASP.NET(80)
src="http://media.yesky.com/adjs/iframe-column/imp7.htm" frameborder="0" width="0" scrolling="no" height="0">
<script language="JavaScript" type="text/javascript"> </script> <script language="JavaScript" src="http://www.yesky.com/TLimages/projs/specdealer/-1_specdealer.js" charset="gb2312" type="text/javascript"></script>
<script language="JavaScript" src="http://www.yesky.com/TLimages/include/newcontentjxs.js" type="text/javascript"></script>
<script language="JavaScript" src="/dayvisittop.js" type="text/javascript"></script> <script language="JavaScript" src="http://www.yesky.com/TLimages/qljs/todaytop.js" type="text/javascript"></script>
<script language="JavaScript" src="http://www.yesky.com/zhuanti/index.js" type="text/javascript"></script> <script language="JavaScript" src="http://www.yesky.com/TLimages/qljs/tbtj.js" type="text/javascript"></script>
<script src="http://www.yesky.com/TLimages/include/yfloor1.js" type="text/javascript"></script>
<script language="JavaScript" src="http://www.yesky.com/TLimages/include/f.js" type=""></script>
<script src="http://media.yesky.com/adjs/column/yesky-richmedia.js" type="text/javascript"></script>
Copyright (C) 1999-2006 Chinabyte.com, All Rights Reserved 版权所有 天极网络
渝ICP证B2-20030003号
商务联系、网站内容、合作建议:010-82657868 详细联系方式 在线提交意见反馈 Powered by 天极内容管理平台CMS4i
商务联系、网站内容、合作建议:010-82657868 详细联系方式 在线提交意见反馈 Powered by 天极内容管理平台CMS4i
<script language="Javascript" type="text/javascript"> var now = new Date(); document.write("
"); </script>
<script type="text/javascript"> var ad_cid; if (window.location.search.substring(1) != "") { ad_cid = window.location.search.substring(1); } else { ad_cid = 428; } </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad1").innerHTML=document.getElementById("span_ad1").innerHTML; document.getElementById("span_ad1").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad9").innerHTML=document.getElementById("span_ad9").innerHTML; document.getElementById("span_ad9").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad10").innerHTML=document.getElementById("span_ad10").innerHTML; document.getElementById("span_ad10").innerHTML=""; </script>
<script type="text/javascript"> if(document.getElementById("contentAdv")) { document.getElementById("contentAdv").innerHTML=document.getElementById("span_ad3").innerHTML; document.getElementById("span_ad3").innerHTML=""; } else { document.getElementById("ad3").innerHTML=document.getElementById("span_ad3").innerHTML; document.getElementById("span_ad3").innerHTML=""; }</script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad5").innerHTML=document.getElementById("span_ad5").innerHTML; document.getElementById("span_ad5").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad11").innerHTML=document.getElementById("span_ad11").innerHTML; document.getElementById("span_ad11").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad2").innerHTML=document.getElementById("span_ad2").innerHTML; document.getElementById("span_ad2").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad4").innerHTML=document.getElementById("span_ad4").innerHTML; document.getElementById("span_ad4").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad7").innerHTML=document.getElementById("span_ad7").innerHTML; document.getElementById("span_ad7").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad8").innerHTML=document.getElementById("span_ad8").innerHTML; document.getElementById("span_ad8").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> document.getElementById("ad6").innerHTML=document.getElementById("span_ad6").innerHTML; document.getElementById("span_ad6").innerHTML=""; </script>
<script language="JavaScript" type="text/javascript"> if (typeof(qltags)=='' || typeof(qltags)=='undefined') { document.write("