原理就是用JS遍列所有CheckBox把所有CheckBox设为未被选中,然后在把单击的CheckBox设为选中

以下是.ASPX文件

<%@ Page language="c#" Codebehind="WebForm1.aspx.cs" AutoEventWireup="false" Inherits="DataGridCheck.WebForm1" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
 <HEAD>
  <title>WebForm1</title>
  <meta content="Microsoft Visual Studio .NET 7.1" name="GENERATOR">
  <meta content="C#" name="CODE_LANGUAGE">
  <meta content="JavaScript" name="vs_defaultClientScript">
  <meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema">
  <SCRIPT language="JavaScript">
     function SetCheckBoxState()
     {
     var dom=document.all;
     var el=event.srcElement;
        if(el.tagName=="INPUT"&&el.type.toLowerCase()=="checkbox")
     {
  for(i=0;i<dom.length;i++)
  {
      if(dom[i].tagName=="INPUT"&&dom[i].type.toLowerCase()=="checkbox")
      {
   dom[i].checked=false;
      }
  }
     }
     el.checked=!el.checked;
        }
  </SCRIPT>
 </HEAD>
 <body MS_POSITIONING="GridLayout">
  <form id="Form1" method="post" runat="server">
   <FONT face="宋体">
    <asp:datagrid id="dg" style="Z-INDEX: 101; LEFT: 168px; POSITION: absolute; TOP: 40px" runat="server"
     Width="440px" AutoGenerateColumns="False">
     <Columns>
      <asp:TemplateColumn>
       <ItemTemplate>
        <asp:CheckBox id="chkExport" runat="server"></asp:CheckBox>
       </ItemTemplate>
      </asp:TemplateColumn>
      <asp:BoundColumn DataField="IntegerValue"></asp:BoundColumn>
      <asp:BoundColumn DataField="StringValue"></asp:BoundColumn>
      <asp:BoundColumn DataField="CurrencyValue"></asp:BoundColumn>
     </Columns>
    </asp:datagrid><asp:button id="Button1" style="Z-INDEX: 102; LEFT: 168px; POSITION: absolute; TOP: 8px" runat="server"
     Text="显示内容"></asp:button></FONT></form>
 </body>
</HTML>

以下是CS文件

using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
namespace DataGridCheck
{
 /**//// <summary>
 /// WebForm1 的摘要说明。
 /// </summary>
 public class WebForm1 : System.Web.UI.Page
 {
  protected System.Web.UI.WebControls.Button Button1;
  protected System.Web.UI.WebControls.DataGrid dg;
 
  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
   if (!Page.IsPostBack)
   {
    dg.DataSource= CreateDataSource() ;
    dg.DataBind();   
   }
   
   
  }
  ICollection CreateDataSource() 
  {
   DataTable dt = new DataTable();
   DataRow dr;
 
   dt.Columns.Add(new DataColumn("IntegerValue", typeof(Int32)));
   dt.Columns.Add(new DataColumn("StringValue", typeof(string)));
   dt.Columns.Add(new DataColumn("CurrencyValue", typeof(double)));
 
   for (int i = 0; i < 9; i++) 
   {
    dr = dt.NewRow();
 
    dr[0] = i;
    dr[1] = "Item " + i.ToString();
    dr[2] = 1.23 * (i + 1);
 
    dt.Rows.Add(dr);
   }
 
   DataView dv = new DataView(dt);
   return dv;
  }


  Web 窗体设计器生成的代码#region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
  
  /**//// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {    
   this.dg.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(this.dg_ItemDataBound);
   this.Button1.Click += new System.EventHandler(this.Button1_Click);
   this.Load += new System.EventHandler(this.Page_Load);

  }
  #endregion

  private void Button1_Click(object sender, System.EventArgs e)
  {
    System.Web.UI.WebControls.CheckBox chkExport;
   foreach (DataGridItem dgItem in dg.Items)
   {
    chkExport=(CheckBox)dgItem.FindControl("chkExport");
    if(chkExport.Checked)
    {
      Response.Write("<script>alert('"+dgItem.Cells[2].Text+"和"+dgItem.Cells[3].Text+"')</script>");
    
    }
   }  
  }

     private void dg_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
  {
   if(e.Item.ItemIndex<0)  return;
   if(e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
   {
     System.Web.UI.WebControls.CheckBox chkExport; 
    chkExport=(CheckBox)e.Item.FindControl("chkExport");
    chkExport.Attributes.Add("OnClick","SetCheckBoxState()");
    e.Item.Attributes.Add("onmouseover","currentcolor=this.style.backgroundColor;this.style.backgroundColor='48d1cc'");
    e.Item.Attributes.Add("onmouseout","this.style.backgroundColor=currentcolor");
   }
  }

 

 }
}


作者Blog:http://blog.csdn.net/listhome/

转载于:https://www.cnblogs.com/leeon/archive/2004/12/10/75061.html

DataGrid中加入CheckBox,并实现单选相关推荐

  1. DataGrid中加入CheckBox,并实现单选 选择自 listhome 的 Blog

    原理就是用JS遍列所有CheckBox把所有CheckBox设为未被选中,然后在把单击的CheckBox设为选中 以下是.ASPX文件 <%@ Page language="c#&qu ...

  2. 选择DataGrid中的CheckBox控件后该行背景变色

    在网络开发中,经常遇到需要使用ASP.NET与JavaScript联合进行控制的情况.在本篇中,将使用DataGrid进行数据绑定,使用Javascript控制当选中其中的checkbox时,该行颜色 ...

  3. ASP.NET与JavaScript联合操作之一 选择DataGrid中的CheckBox控件后该行背景变色

    在网络开发中,经常遇到需要使用ASP.NET与JavaScript联合进行控制的情况.在本篇中,将使用DataGrid进行数据绑定,使用Javascript控制当选中其中的checkbox时,该行颜色 ...

  4. 用js 判断datagrid 中的 checkbox 是否被选中

    private void Page_Load(object sender, System.EventArgs e)         {             // 在此处放置用户代码以初始化页面   ...

  5. php 单选框选中事件,html中的checkbox和radio事件选择用法详解

    radio注册了click事件以后,神奇的是用键盘上的上下左右选择时,居然会触发鼠标事件,滚轮也会触发,这种神奇的事情在mousedown下面是不会发生的.(webkit不能使用上下左右选择) che ...

  6. 代码分析-DataGrid实现自增列、单选、多选

    上一次,我们为这个DataGrid实现了添加.删除.修改.分页.动态修改内容等功能,今天再来分析一下如何为之添加自增列.单选.多选的功能. 首先看一下需要在上次的基础上增加的代码: (1)实现自增列 ...

  7. 在WPF的DATAGRID中快速点击出现在ADDNEW或EDITITEM事务过程不允许DEFERREFRESH

    在WPF的DATAGRID中快速点击出现在ADDNEW或EDITITEM事务过程不允许DEFERREFRESH 原文 在WPF的DATAGRID中快速点击出现在ADDNEW或EDITITEM事务过程不 ...

  8. 在DataGrid中合并单元格行

    最近在做项目的时候经常遇到要合并单元格的情况,发现这个东西.net中并没有现成的方法,研究了一下,总结了两种方法. 这个主要都是行合并的,有以下两种情况 1.多行合并为一行,其中将某个或某几个单元格的 ...

  9. 在DataGrid中选择,确认,删除多行复选框列表

    在DataGrid中选择,确认,删除多行复选框列表 Selecting, Confirming & Deleting Multiple Checkbox Items In A DataGrid ...

最新文章

  1. 阿里巴巴电商平台架构演变之路
  2. 《javascript高级程序设计》笔记:变量对象与预解析
  3. 2019年,被高估的AI与数据科学该如何发展?
  4. python统计字符在文件中出现的次数_python字符串中字符出现次数(python获取字符串个数)...
  5. SSM中向后端传递的属性为多个对象的实现方法
  6. 细述:nginx http内核模块提供的变量和解释
  7. 前端学习(1859)vue之电商管理系统电商系统之梳理项目结构
  8. 《MFC游戏开发》笔记四 键盘响应和鼠标响应:让人物动起来
  9. php atlas,Apache Atlas是什么意思
  10. 对讲机写频教程以(TCL-HT9为例)
  11. 两台计算机怎样共享一台打印机共享文件夹,二台不同系统电脑怎么样共享一台打印机...
  12. 最优化学习 拟牛顿法(Quasi-Newton Method)
  13. Flask(python)恶补笔记
  14. java对接portal协议_Portal协议分析
  15. Janky frames 是如何计算出来的
  16. robocup3d教程
  17. Python Eric7+PyQt6环境配置,GUI程序开发
  18. Paging3 分页库的使用
  19. 福建学业水平考试技能考Windows Server 服务器的配置真题
  20. 软件平台项目设计开发流程

热门文章

  1. 腾讯开源国内首个H.266/VVC视频播放器
  2. CVPR 2019 | 步步为营!通过迭代式模糊核预测提高超分辨质量
  3. mysql killed状态连接_MySQL: kill connection的实现简析
  4. 「Python基础知识」Python的split方法如何使用
  5. C++ Primer 第五版 第6章 6.2——函数参数传递阅读笔记
  6. 资源下载!5本从Python入手机器学习的必备电子书!(附下载链接)
  7. 【嵌入式工程师面试高频问题】你知道IIC吗(附程序说明)
  8. 大数据分析实战-信用卡欺诈检测(五)-逻辑回归模型
  9. 推荐系统遇上深度学习(七)--NFM模型理论和实践
  10. 深度强化学习-Actor-Critic算法原理和实现