使用javascript实现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>

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.     }

OK!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值