GridView选中行变色(无刷新)

 

以前在网上找过不少方法,但不是不好用就是要刷新页面,昨天把以前做的一个需要刷新选中行的代码修改了一下,还挺好用,拿出来大家分享一下,有需要改进之处,欢迎指正!

实现方式:通过javascript进行控制,点击行中任何一个位置,改行被选中变色。

1、首先在.aspx页面块中添加javascript

 1  < script type = " text/javascript " >
 2      var prevselitem = null ;
 3      function selectx(row)
 4      {
 5               if (prevselitem != null )
 6              {
 7                  prevselitem.style.backgroundColor = ' #ffffff ' ;
 8              }
 9              row.style.backgroundColor = ' PeachPuff ' ;
10              prevselitem = row;
11              
12      }
13  </ script >
14 
15 

2、然后修改GridView,添加事件OnRowDataBound,如:
1  < asp:GridView ID = " GridView1 "  runat = " server "  AllowPaging = " True "  AutoGenerateColumns = " False "   Width = " 100% "  PageSize = " 12 "  OnRowDataBound = " GridView1_RowDataBound " >
2  // 省略
3  </ asp:GridView >
3、最后在.aspx.cs页面中添加
 1  protected   void  GridView1_RowDataBound( object  sender,GridViewRowEventArgs e)
 2      {
 3            if  (e.Row.RowType  ==  DataControlRowType.DataRow)
 4              {
 5                  e.Row.Attributes.Add( " onmouseover " " if(this!=prevselitem){this.style.backgroundColor='#Efefef'} " ); // 当鼠标停留时更改背景色
 6                  e.Row.Attributes.Add( " onmouseout " " if(this!=prevselitem){this.style.backgroundColor='#ffffff'} " ); // 当鼠标移开时还原背景色
 7                  e.Row.Attributes.Add( " onclick " , e.Row.ClientID.ToString()  +   " .checked=true;selectx(this) " );
 8              }
 9      }
10 
11 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值