Gridview使用CheckBox全选与单选 Version 2

本文详细介绍了如何在Insus.NET中实现GridView头中的CheckBox功能,实现对Gridview行的全选与全取消操作,包括代码实现与演示数据准备。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在前一版本中,Insus.NET已经实现GridView头中放置CheckBox,可以对Gridview的行进行全选或是全取消的操作。
http://www.cnblogs.com/insus/archive/2013/01/20/2868532.html

更早前一版:
http://www.cnblogs.com/insus/articles/1411613.html

此次版本,主要是实现Gridview的Header的CheckBox 选择的效果。 如果所有记录行非选择时,改变此CheckBox的效果。
OK, 演示之前,先准备演示数据与环境。
首先写好一个对象:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

/// <summary>
/// Summary description for Soup
/// </summary>
namespace Insus.NET
{
    public class Soup
    {
        private string _Area;
        private string _Country;
        private string _SoupName;

        public string Area
        {
            get { return _Area; }
            set { _Area = value; }
        }
        public string Country
        {
            get { return _Country; }
            set { _Country = value; }
        }
        public string SoupName
        {
            get { return _SoupName; }
            set { _SoupName = value; }
        }

        public Soup()
        {
            //
            // TODO: Add constructor logic here
            //
        }
        public Soup(string area, string country, string soupName)
        {
            this._Area = area;
            this._Country = country;
            this._SoupName = soupName;
        }
    }
}
Insus.NET.Soup


为刚才写好的对象,填充数据:

 public List<Soup> GetAllData()
    {
        List<Soup> s = new List<Soup>();
        s.Add(new Soup("亚洲", "中国", "杏香红枣鸡腿汤"));
        s.Add(new Soup("亚洲", "中国", "老火汤"));
        s.Add(new Soup("亚洲", "中国", "当归汤"));
        s.Add(new Soup("亚洲", "泰国", "冬荫功汤"));
        s.Add(new Soup("亚洲", "印度", "咖喱肉汤"));
        s.Add(new Soup("亚洲", "中国", "佛跳墙"));
        s.Add(new Soup("亚洲", "日本", "味噌汤"));       
        s.Add(new Soup("美洲", "美国", "周打蚬汤"));
        s.Add(new Soup("欧洲", "法国", "马赛鱼汤"));
        s.Add(new Soup("欧洲", "西班牙", "西班牙冷汤"));
        s.Add(new Soup("欧洲", "俄国", "罗宋汤"));
        return s;
    }
View Code


在站点中,创建一个网页,并拉一个Gridview控件至网页中(这操作你懂的),然后改写一下这个GridVeiw控件:

<asp:GridView ID="GridView1" 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>
                            Area
                        </HeaderTemplate>
                        <ItemTemplate>
                            <%# Eval("Area") %>
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField>
                        <HeaderTemplate>
                            Country
                        </HeaderTemplate>
                        <ItemTemplate>
                            <%# Eval("Country") %>
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:TemplateField>
                        <HeaderTemplate>
                            Soup Name
                        </HeaderTemplate>
                        <ItemTemplate>
                            <%# Eval("SoupName") %>
                        </ItemTemplate>
                    </asp:TemplateField>
                </Columns>
            </asp:GridView>
View Code


去.aspx.cs为GridView控件绑定数据:




在.aspx的GridView控件中,不管是在Header还是Row的CheckBox,均有一个Javascript的方法。接下来,我们完成Javascript脚本:
 下面是Head CheckBox:


下面是Row的CheckBox单选脚本:



写好了,运行看看:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值