以前在網上找過不少方法,但不是不好用就是要重新整理頁面,昨天把以前做的一個需要重新整理選中行的代碼修改了一下,還挺好用,拿出來大家分享一下,有需要改進之處,歡迎指正!
實現方式:通過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