<%@ Page Language="C#" AutoEventWireup="true" Codebehind="Default.aspx.cs" Inherits="WebApplication2._Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>未命名頁面</title>
    <style type="text/css">       
    .hide{display:none;}  
    </style>

<script type="text/javascript">        //选中所有行       
    function SelectAll(chkAll)      
     {          
      var gridview = document.getElementById("GridView1");      
           if (gridview)     
                 {             
                  //获取到GridView1中的所有input标签             
                  var inputs = gridview.getElementsByTagName("input");           
                     for(var i=0;i<inputs.length;i++)          
                         {           
                             if (inputs[i].type=="checkbox")    
                                   {              
                                        //设置所有checkbox的选中状态与chkAll一致           
                                        inputs[i].checked = chkAll.checked;     
                                     }      
                          }     
         }  
      }         
                                                                                          
 //给选中行换背景色      
      function checkRow(chkRow)     
       {        
          var row = chkRow.parentNode.parentNode;    
              if(row)        
                {             
                    if (chkRow.checked)    
                        row.style.backgroundColor="#7799CC";
                         else  
                          row.style.backgroundColor="#FFFFFF";
                           }      
                           }  
    </script>

</head>
<body>
    <form id="form1" runat="server">
        <div>
            <asp:LinkButton ID="lbtnAddRow" runat="server" Width="80px" OnClick="lbtnAddRow_Click">添加行</asp:LinkButton>
            <asp:LinkButton ID="btnDeleteRow" runat="server" OnClick="btnDeleteRow_Click" OnClientClick="return confirm('确定要删除选中行吗?');">删除选中行</asp:LinkButton>
        </div>
        <div>
            <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False" CellPadding="4"
                ForeColor="#333333">
                <Columns>
                    <asp:BoundField DataField="ID" HeaderText="ID">
                        <ItemStyle CssClass="hide" BorderColor="#507CD1" />
                        <HeaderStyle CssClass="hide" />
                    </asp:BoundField>
                    <asp:TemplateField HeaderText="序号">
                        <ItemTemplate>
                            <%# Container.DataItemIndex + 1%>
                        </ItemTemplate>
                        <ItemStyle BorderColor="#507CD1" HorizontalAlign="Center" BorderWidth="1px" />
                    </asp:TemplateField>
                    <asp:TemplateField>
                        <HeaderTemplate>
                            <input id="chkAll" type="checkbox" onclick="SelectAll(this)" />
                        </HeaderTemplate>
                        <ItemTemplate>
                            <input id="chkRow" type="checkbox" onclick="checkRow(this);" runat="server" />
                        </ItemTemplate>
                        <ItemStyle Width="30px" HorizontalAlign="Center" BorderColor="#507CD1" BorderWidth="1px" />
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="姓名">
                        <ItemTemplate>
                            <asp:TextBox ID="txtName" runat="server" Text='<%# Bind("Name") %>' BorderStyle="None"></asp:TextBox>
                        </ItemTemplate>
                        <ItemStyle Width="100px" BorderColor="#507CD1" BorderWidth="1px" />
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="平时成绩">
                        <ItemTemplate>
                            <asp:TextBox ID="txtUsuallyResults" runat="server" Text='<%# Bind("UsuallyResults") %>'
                                BorderStyle="None"></asp:TextBox>
                        </ItemTemplate>
                        <ItemStyle Width="100px" BorderColor="#507CD1" BorderWidth="1px" />
                    </asp:TemplateField>
                    <asp:TemplateField HeaderText="考试成绩">
                        <ItemTemplate>
                            <asp:TextBox ID="txtExamResults" runat="server" Text='<%# Bind("ExamResults") %>'
                                BorderStyle="None"></asp:TextBox>
                        </ItemTemplate>
                        <ItemStyle Width="100px" BorderColor="#507CD1" BorderWidth="1px" />
                    </asp:TemplateField>
                </Columns>
                <HeaderStyle BackColor="#507CD1" Font-Bold="True" ForeColor="White" />
            </asp:GridView>
        </div>
    </form>
</body>
</html>

-----------------------------------

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

namespace WebApplication2
{
    public partial class _Default : System.Web.UI.Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            if (!Page.IsPostBack) {
                DataTable table = new DataTable();
                table.Columns.Add(new DataColumn("ID"));
                table.Columns.Add(new DataColumn("Name"));
                table.Columns.Add(new DataColumn("UsuallyResults"));
                table.Columns.Add(new DataColumn("ExamResults"));
                DataRow row = table.NewRow();
                table.Rows.Add(row);
                GridView1.DataSource = table; GridView1.DataBind();
            }
        }
        protected void lbtnAddRow_Click(object sender, EventArgs e)
        {
            DataTable table = GetGridViewData();

DataTable table1 = new DataTable();
            table1.Columns.Add(new DataColumn("ID"));
            table1.Columns.Add(new DataColumn("Name"));
            table1.Columns.Add(new DataColumn("UsuallyResults"));
            table1.Columns.Add(new DataColumn("ExamResults"));
            DataRow newRow1 = table1.NewRow();
            newRow1["ID"] = Guid.NewGuid().ToString();
            table1.Rows.Add(newRow1);
           // foreach (DataRow dr in table1.Rows)
           // {
            for(int i=0;i<table.Rows.Count;i++)
            {
                DataRow sourseRow = table1.NewRow();
                sourseRow["ID"] =table.Rows[i]["ID"].ToString();
                sourseRow["Name"] = table.Rows[i]["name"].ToString(); ;
                sourseRow["UsuallyResults"] = "2";
                sourseRow["ExamResults"] ="1";
                table1.Rows.Add(sourseRow);
            }
           // }
            GridView1.DataSource = table1;
            GridView1.DataBind();

}   
        private DataTable GetGridViewData()
        {
            DataTable table = new DataTable();
            table.Columns.Add(new DataColumn("ID"));
            table.Columns.Add(new DataColumn("Name"));
            table.Columns.Add(new DataColumn("UsuallyResults"));
            table.Columns.Add(new DataColumn("ExamResults"));
            foreach (GridViewRow row in GridView1.Rows)
            {
                DataRow sourseRow = table.NewRow();
                sourseRow["ID"] = row.Cells[0].Text;
                sourseRow["Name"] = ((TextBox)row.Cells[3].FindControl("txtName")).Text;
                sourseRow["UsuallyResults"] = ((TextBox)row.Cells[4].FindControl("txtUsuallyResults")).Text;
                sourseRow["ExamResults"] = ((TextBox)row.Cells[5].FindControl("txtExamResults")).Text;
                table.Rows.Add(sourseRow);
            }
            return table;
        }

protected void btnDeleteRow_Click(object sender, EventArgs e)
        {   DataTable table = GetGridViewData();
            foreach (GridViewRow row in GridView1.Rows)
            {
                if (((HtmlInputCheckBox)row.Cells[2].FindControl("chkRow")).Checked)
            { foreach (DataRow dtRow in table.Rows)
            { if (dtRow["ID"].ToString() == row.Cells[0].Text)
            {
                table.Rows.Remove(dtRow);
                break;
            }
            }
                }
            }
            GridView1.DataSource = table; GridView1.DataBind();
        }
    }
}

gridview 第一行编辑的更多相关文章

  1. EasyUI DataGrid 实现单行/多行编辑功能

    要实现 EasyUI DataGrid 的可编辑很简单,在需要编辑的列添加 editor [编辑器]就可以了. 单行编辑 // 初始化数据列表 function initDatagrid() { $( ...

  2. linux编辑文本(vim)时跳转到最后一行和第一行及相关指令

    vi操作 1.跳到文本的最后一行:按“G”,即“shift+g” 2.跳到最后一行的最后一个字符 : 先重复1的操作即按“G”,之后按“$”键,即“shift+4”. 3.跳到第一行的第一个字符:先按 ...

  3. GridView/DataGrid行单击和双击事件实现代码_.Net教程

    功能: 单击选中行,双击打开详细页面 说明:单击事件(onclick)使用了 setTimeout 延迟,根据实际需要修改延迟时间 ;当双击时,通过全局变量 dbl_click 来取消单击事件的响应  ...

  4. DEV express 对Gridview某行的元素赋值

    1:获取选中的行某列的值 string colValue= this.gridView1.GetRowCellValue(this.gridView1.FocusedRowHandle, this.g ...

  5. Jquery easyui开启行编辑模式增删改操作

    Jquery easyui开启行编辑模式增删改操作 Jquery easyui开启行编辑模式增删改操作先上图 Html代码: <table id="dd"> </ ...

  6. [转]Jquery easyui开启行编辑模式增删改操作

    本文转自:http://www.cnblogs.com/nyzhai/archive/2013/05/14/3077152.html Jquery easyui开启行编辑模式增删改操作先上图 Html ...

  7. Linux命令行编辑快捷键

    Linux命令行编辑快捷键: history 显示命令历史列表 ↑(Ctrl+p) 显示上一条命令 ↓(Ctrl+n) 显示下一条命令 !num 执行命令历史列表的第num条命令 !! 执行上一条命令 ...

  8. 历时一年,我的著作《第一行代码——Android》已出版!

    前言 事实上我当初决定開始写博客的想法挺简单的,认为自己搞技术这么多年了,总应该要留下点什么.既然没能写出什么出色的应用,那至少也要留下点文字分享给大家,以指引在我后面的开发人员们,毕竟我也从前辈们的 ...

  9. 20172327 2018-2019-1 《第一行代码Android》第二章学习总结

    学号 2017-2018-2 <第一行代码Android>第二章学习总结 教材学习内容总结 - 活动是什么: 活动(Activity)是最容易吸引用户的地方,它是一种可以包含用户界面的组件 ...

随机推荐

  1. python 验证码识别初探

    使用 pytesser 与 pytesseract 识别验证码 前置 :  首先需要安装  tesserract tesserract windows 安装包及中文 https://pan.baidu ...

  2. 20155206 《JAVA程序设计》实验二(JAVA面向对象程序设计)实验报告

    20155206 <JAVA程序设计>实验二(JAVA面向对象程序设计)实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S ...

  3. 20155226 mini DC 课堂测试补交

    由于电脑突然出了点问题,我没有完成mini DC这个测试,现将测试内容及结果补交 题目如下 提交测试截图和码云练习项目链接,实现Linux下dc的功能,计算后缀表达式的值 代码如下 MyDC.clas ...

  4. wmware 10 升级到11后,macos不能运行的问题

    解决方案: 1.由于wmware升级,原来的unlocker已不能使用. 所以得升级unlocker版本,目前支持wmware11的最新版本是2.0.4 http://www.insanelymac. ...

  5. OpenCV中Mat操作clone() 与copyto()的区别

    OpenCV中Mat操作clone() 与copyto()的区别 // Mat is basically a class with two data parts: the matrix header ...

  6. 【转载】GC基本算法及C++GC机制

    原文: GC基本算法及C++GC机制 阅读目录 前言 基本概念 有向可达图与根集 三种基本的垃圾收集算法及其改进算法 1.引用计数算法 2. Mark & Sweep 算法 3. 节点复制算法 ...

  7. Struts 2(三):示例→基于Struts 2的用户注册模块

    示例→基于Struts2的用户注册模块 1.用户注册模块需求描述 在用户注册页面中填写用户信息,包括用户名.用户密码.确认密码.姓名等信息,填写完成后提交注册表单给Struts 2的业务控制器Acti ...

  8. javaweb(十六)——JSP指令

    一.JSP指令简介 JSP指令(directive)是为JSP引擎而设计的,它们并不直接产生任何可见输出,而只是告诉引擎如何处理JSP页面中的其余部分. 在JSP 2.0规范中共定义了三个指令: pa ...

  9. 【一】H.264/MPEG-4 Part 10 White Paper 翻译之 Overview of H.264

    翻译版权所有,转载请注明出处~ xzrch@2018.09.14 ------------------------------------------------------------------- ...

  10. 如何快速解决MySQL 1032 主从错误

    3分钟解决MySQL 1032主从错误 Part1:写在最前1032错误----现在生产库中好多数据,在从库误删了,生产库更新后找不到了,现在主从不同步了,再跳过错误也没用,因为没这条,再更新还会报错 ...