Gridview使用CheckBox全选与单选
Insus.NET对Gridview使用CheckBox单选与全选功能再次进行简单演示,选中的行,使用高亮显示,让用户一目了然看到哪一行被选择了。本例中,使用前端脚本Javascript来实现。还是先看看Insus.NET做出来的效果:
Insus.NET原本是从数据库获取数据并绑定至GridView控件的,为了在学asp.net的网友,也能轻易操作,因此这个想法,采用对象存储数据。
首先创建一个对象,[对联]的对象:

using System; using System.Collections.Generic; using System.Linq; using System.Web; /// <summary> /// Summary description for Couplets /// </summary> namespace Insus.NET { public class Couplets { private int _ID; private string _Type; private string _Content; public int ID { get { return _ID; } set { _ID = value; } } public string Type { get { return _Type; } set { _Type = value; } } public string Content { get { return _Content; } set { _Content = value; } } public Couplets() { // // TODO: Add constructor logic here // } public Couplets(int id, string type, string content) { this._ID = id; this._Type = type; this._Content = content; } } }
对象准备好,它是的空的对象,所以还得为刚才创建好的对象,填充数据,让它成为真正的实体。

public List<Couplets> GetData() { List<Couplets> couplets = new List<Couplets>(); Couplets c = new Couplets(1, "四字联", "一元复始;万象更新。"); couplets.Add(c); c = new Couplets(2, "四字联", "风调雨顺;国盛人和。"); couplets.Add(c); c = new Couplets(3, "四字联", "风调雨顺;国盛人和。"); couplets.Add(c); c = new Couplets(4, "五字联", "金蛇含瑞草;紫燕报新春。"); couplets.Add(c); c = new Couplets(5, "五字联", "龙年留胜绩;蛇岁展宏猷。"); couplets.Add(c); c = new Couplets(6, "七字联", "壬辰传捷龙辞旧;癸巳报春蛇迎新。"); couplets.Add(c); c = new Couplets(7, "七字联", "山高水远人增志;蛇接龙年地满春。"); couplets.Add(c); c = new Couplets(8, "七字联", "小龙起舞神州地;祖国腾飞大治年。"); couplets.Add(c); c = new Couplets(9, "七字联", "金山水漫双蛇舞;绿野春归百鸟鸣。"); couplets.Add(c); return couplets; }
在Default.aspx网页上拉一个GridView控件。

<asp:GridView ID="GridViewCouplets" runat="server" AutoGenerateColumns="false"> <Columns> <asp:TemplateField> <HeaderTemplate> <asp:CheckBox ID="CheckBox1" runat="server" ToolTip="全选" onclick="SelectedAll(this);" /> </HeaderTemplate> <ItemTemplate> <asp:CheckBox ID="CheckBox2" runat="server" onclick="SelectedSingle(this);" /> </ItemTemplate> </asp:TemplateField> <asp:TemplateField> <HeaderTemplate> ID </HeaderTemplate> <ItemStyle HorizontalAlign="Right" /> <ItemTemplate> <%# Eval("ID") %> </ItemTemplate> </asp:TemplateField> <asp:TemplateField> <HeaderTemplate> Type </HeaderTemplate> <ItemTemplate> <%# Eval("Type") %> </ItemTemplate> </asp:TemplateField> <asp:TemplateField> <HeaderTemplate> Content </HeaderTemplate> <ItemTemplate> <%# Eval("Content") %> </ItemTemplate> </asp:TemplateField> </Columns> </asp:GridView>
接下来,还得通过Default.aspx.cs页面为GridView绑定数据。

using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.UI; using System.Web.UI.WebControls; using Insus.NET; public partial class _Default : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { if (!IsPostBack) Data_Binding(); } private void Data_Binding() { this.GridViewCouplets.DataSource = GetData(); this.GridViewCouplets.DataBind(); } }
在上面的html代码中,可以看有两个CheckBhox,一个是放在GridView的HeaderTemplate模版上为了全选,另一个是放在ItemTemplate模版上为了单选。
每一个CheckBox都有一个OnClick事件,可参考如下Javascript代码:

<script type="text/javascript"> function SelectedAll(cb) { cb.checked = cb.checked ? false : true; var gv = document.getElementById('<%=GridViewCouplets.ClientID %>'); var rc = gv.rows.length; for (var i = 1; i < rc; i++) { var input = gv.rows[i].cells[0].getElementsByTagName("input"); if (input[0].type == "checkbox" && input[0].checked) { input[0].checked = false; gv.rows[i].style.backgroundColor = ""; } else { input[0].checked = true; gv.rows[i].style.backgroundColor = "#66ff33;"; } } } function SelectedSingle(cb) { var row = cb.parentNode.parentNode; if (cb.checked) { row.style.backgroundColor = "#66ff33;"; } else { row.style.backgroundColor = ""; } } </script>
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
2012-01-20 无法解决 equal to 操作中 "SQL_Latin1_General_CP1_CI_AS" 和 "Chinese_PRC_CI_AS" 之间的排序规则冲突。
2012-01-20 sp_executesql 使用复杂的 Unicode 表达式
2012-01-20 OBJECTPROPERTY与sp_rename更改对象名称
2010-01-20 Generics and Linq demo
2010-01-20 Two ListBox selector demo