Gridview 用法大全三

在VS2005提供的GridView中我们可以直接添加一个CommandField删除列:<asp:CommandField ShowDeleteButton="True" />,然后在GridView的OnRowDeleting事件中完成删除。但一般情况下我们在做这种删除操作时都需要先让用户确认一下,然后后再删除记录,以避免误操作引起的误删除。

那我们可以通过下面方法给GridView删除前加上一个确认对话框。

首先,在GridView的属性对框话框中点击“Columns”进入它的"字段"设计器;或者在设计窗口直接点击GridView控件右上角的那个小箭头,点击"编辑列",进入"字段"设计器。

接着在"字段"设计器中的左下方"选定的字段"框中,选择以前已加上的那个CommandField“删除”列,这时在右边它的属性列表下会看到一个"将此它段转换为 TemplateFied"的项,点击将它转换为TemplateFied列。

然后退出"字段"设计器,切换到源码视图你会发现该列已由原来的:
<asp:CommandField ShowDeleteButton="True" />
变为了:

4f6b3cfb2f9b3e1b242df23f.jpg < asp:TemplateField ShowHeader ="False" >
c94e855bdf9c8a682934f03f.jpg                                  
< ItemTemplate >
3b493128d4856ad9023bf63f.jpg                                      
< asp:LinkButton ID ="LinkButton1" runat ="server" CausesValidation ="False"
7e3dc02f2f9b7676359bf73f.jpg
1d5fbeb7c9584b8c37d3ca3f.jpgCommandName
="Delete"      Text ="删除" ></ asp:LinkButton >
ca4ecd36c92a5d795ab5f53f.jpg
</ ItemTemplate >
45d12ce8147c6891d439c93f.jpg

最后在<asp:LinkButton>中加入:OnClientClick="return confirm('您确认删除该记录吗?');"

这样点击删除时就会先在客户端弹出“您确认删除该记录吗?”对话框,点击"确定",则进行删除;点击"取消",则不删除.
而原来在onRowDeleting事件中写的代码完全不用改变。鼠标在GridView上移动时变换颜色

28b7303bb2b264b13b87ce3f.jpg protected void GridView1_RowCreated( object sender, GridViewRowEventArgs e)
a864dff13c35b712342acc3f.jpg24e30c523d98981e1138c23f.jpg          
2b4e235e1a8a0d01faf2c03f.jpg {
cb5d53023f4164c5e850cd3f.jpg              
if (e.Row.RowType == DataControlRowType.DataRow )
0e5cb641f740ec539213c63f.jpge59657139da1ee3ccb80c43f.jpg              
8d77557cda323b7a0dd7da3f.jpg{
d4e4803a1e65cf6196ddd83f.jpg                   e.Row.Attributes.Add(
"onmouseover", "currentcolor=this.style.backgroundColor;this.style.backgroundColor='#C0C0FF';this.style.cursor='hand';");
89b94446bb8607c0b3b7dc3f.jpg                  
//当鼠标移走时还原该行的背景色
2497df85eee26b68c75cc33f.jpg
                   e.Row.Attributes.Add("onmouseout", "this.style.backgroundColor=currentcolor");
b350bc80aa058ee00df4d23f.jpg               }

acd335a016466fefcaefd03f.jpg           }

RowCreated:开被创建时发生
e.Row.RowType == DataControlRowType.DataRow 判断是否是数据行
DataControlRowType的枚举有:
DataRow数据行
EmptyDataRow
Footer
Header
Pager
Separator
如果对单元格进行变换。

1290d4afd75d284b4a36d63f.jpg if (e.Row.Cells[ 8 ].Text == " USA " )
f734d028cfee4e7a5243c13f.jpgd838f53a58f1a5b0b311c73f.jpg               
d58b930b5584f2ed2fddd43f.jpg {
555249ad0e6ffd8e7dd92a3f.jpg                   
//e.Row.BackColor = System.Drawing.Color.Red; //修改整行的颜色
4d271ef0bfa3cd51b17ec53f.jpg
                    e.Row.Cells[8].BackColor = System.Drawing.Color.Red;     //修改单元格的颜色(第9列)
30b946ce5e6bd35200e9283f.jpg
                }

不足。前端页面代码过多。站带宽。
在GridView的第一列使用CheckBox控制每一行数据,是经常使用的,这里面我要记录的是全选、全消、选中行的底色更改,还有就是在提交数据的时候,取选中的行的编号等功能

转载于:https://www.cnblogs.com/30ErLi/archive/2010/09/17/1828863.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值