案例:在表格中进行新增一行与删除一行

1.情况

  

2.思路

  /*
    * 为 #employeetable 的所有的 a 节点添加 Onclick 响应函数:
    * 1. 弹出确认对话框: 确定要删除 xx 的信息吗? xx 为当前 a 节点所在的 td 所在的 tr 的
    * 第一个 td 子节点的文本值, 且要去除前后空格.
    * 2. 若点击 "确认" , 则删除 a 节点的所在的 行
    *
    * 注意:
    * 1. a 节点是一个超级链接, 可以在其 onclick 事件中通过返回 false, 来取消默认行为
    * 2. tr 的直接父节点为 tbody, 而不是 table
    * 3. 可以把去除前后空格的代码写成一个 trim(str) 函数.
    *
    * 为 #addEmpButton 添加 onclick 响应函数:
    * 1. 获取 #name, #email, #salary 的文本框的值
    * 2. 利用 1 获取的文本值创建 3 个 td 节点, 在创建一个 tr 节点. 并把以上的 3 个 td
    * 节点价位 tr 节点的子节点
    <tr>
      <td>Tom</td>
      <td>[email protected]</td>
      <td>5000</td>
    </tr>
    * 3. 在创建一个 td 节点: <td><a href="deleteEmp?id=xxx">Delete</a></td>
    * 4. 把 3 创建的 td 也加为 tr 的子节点.
    * 5. 再把 tr 加为 #employeetable 的 tbody 子节点的子节点.
    * 6. 为新创建的 tr 的 a 子节点添加 Onclick 响应函数, 使其也具备删除的功能.
    *
  */

3.程序

  1 <!DOCTYPE html>
  2 <html>
  3 <head>
  4 <meta charset="UTF-8">
  5 <title>Insert title here</title>
  6 <script type="text/javascript">
  7     window.onload=function(){
  8         //删除节点
  9         var aNodes = document.getElementById("employeetable")
 10             .getElementsByTagName("a");
 11         for(var i = 0; i < aNodes.length; i++){
 12             aNodes[i].onclick = function(){
 13                 removeTr(this);
 14                 return false;
 15             }
 16         }
 17         //新增节点
 18         document.getElementById("addEmpButton").onclick = function(){
 19              var nameVal = document.getElementById("name").value;
 20              var emailVal = document.getElementById("email").value;
 21              var salaryVal = document.getElementById("salary").value;
 22
 23              var nameTd = document.createElement("td");
 24              nameTd.appendChild(document.createTextNode(nameVal));
 25              var emailTd = document.createElement("td");
 26              emailTd.appendChild(document.createTextNode(emailVal));
 27              var salaryTd = document.createElement("td");
 28              salaryTd.appendChild(document.createTextNode(salaryVal));
 29
 30              var tr = document.createElement("tr");
 31              tr.appendChild(nameTd);
 32              tr.appendChild(emailTd);
 33              tr.appendChild(salaryTd);
 34
 35              //<td><a href="deleteEmp?id=xxx">Delete</a></td>
 36              var aNode = document.createElement("a");
 37              aNode.href = "deleteEmp?id=xxx";
 38              aNode.appendChild(document.createTextNode("Delete"));
 39              var aTd = document.createElement("td");
 40              aTd.appendChild(aNode);
 41              tr.appendChild(aTd);
 42
 43              aNode.onclick = function(){
 44                  removeTr(this);
 45                  return false;
 46              }
 47
 48              document.getElementById("employeetable")
 49                      .getElementsByTagName("tbody")[0]
 50                      .appendChild(tr);
 51         }
 52     }
 53     //删除函数
 54     function removeTr(aNoe){
 55          var trNode = aNoe.parentNode.parentNode;
 56          var textContent = trNode.getElementsByTagName("td")[0]
 57                                  .firstChild.nodeValue;
 58          textContent = trim(textContent);
 59          var flag = confirm("确定要删除" + textContent + "的信息吗?");
 60          if(flag){
 61              trNode.parentNode.removeChild(trNode);
 62          }
 63          return false;
 64      }
 65     //去空格函数
 66     function trim(str){
 67          var reg = /^\s*|\s*$/g;
 68          return str.replace(reg, "");
 69      }
 70 </script>
 71 </head>
 72 <body>
 73     <center><br><br>
 74     添加新员工 <br><br>
 75     name: <input type="text" name="name" id="name" />&nbsp;&nbsp;
 76     email: <input type="text" name="email" id="email" />&nbsp;&nbsp;
 77     salary: <input type="text" name="salary" id="salary" /> <br> <br>
 78
 79     <button id="addEmpButton">Submit</button><br><br><hr><br><br>
 80
 81     <table id="employeetable" border="1" cellpadding="5" cellspacing=0>
 82         <tbody>
 83             <tr>
 84                 <th>Name</th>
 85                 <th>Email</th>
 86                 <th>Salary</th>
 87                 <th>&nbsp;</th>
 88             </tr>
 89             <tr>
 90                 <td>Tom</td>
 91                 <td>[email protected]</td>
 92                 <td>5000</td>
 93                 <td><a href="deleteEmp?id=001">Delete</a></td>
 94             </tr>
 95             <tr>
 96                 <td>
 97                     Jerry
 98                 </td>
 99                 <td>[email protected]</td>
100                 <td>8000</td>
101                 <td><a href="deleteEmp?id=002">Delete</a></td>
102             </tr>
103             </tbody>
104         </table>
105     </center>
106 </body>
107 </html>

4.运行结果

  新增一行

  

  删除一行

  

时间: 2024-11-07 18:50:19

案例:在表格中进行新增一行与删除一行的相关文章

mysql5.7基础 更新表格中某列为指定数据的 一行

镇场文:       学儒家经世致用,行佛家普度众生,修道家全生保真,悟易理象数通变.以科技光耀善法,成就一良心博客.______________________________________________________________________________________________________ Operating System:UbuntuKylin 16.04 LTS 64bitmysql: Ver 14.14 Distrib 5.7.17, for Linux (

利用jquery给指定的table动态添加一行、删除一行

$("#mytable tr").find("td:nth-child(1)") 1表示获取每行的第一列$("#mytable tr").find("td:nth-child(3)") 3表示获取每行的第三列 今天在项目中,刚好用到给指定的table添加一行.删除一行,就直接找google,搜出来的东西不尽如人意,不是功能不好就是千篇一律,简直浪费时间还不讨好,于是乎就自己动手封装个,现就把代码分享出来,避免大伙重复造轮子,如

C# 如何在Excel表格中插入、编辑和删除批注

概述 为文档添加必要的批注可以给文档使用者提供重要的提示信息,下面的示例中,将介绍通过C#编程语言来给Excel表格中的指定单元格内容添加批注,此外,对于已有的批注,如果需要修改,我们也可以进行编辑或者删除批注.示例内容将包含以下主要内容:1.插入批注1.1 插入文本1.2 插入图片2.编辑批注2.1 修改批注内容2.1 设置批注可见性3.删除批注 工具 Spire.XLS for .NET 8.0 提示:在进行代码操作之前,需下载安装Spire.Xls,并添加引用dll文件,添加如下using

在一个table中动态添加一行或删除一行

<table id="selected_user_table" width="100%" > <thead> <tr><th class="center" colspan="2"  style="background-color:#F2F2F2;height:20px;">已选择</th></tr> </thead> <

mysql5.7基础 删除表格中某列为指定数据的 一行

镇场文:       学儒家经世致用,行佛家普度众生,修道家全生保真,悟易理象数通变.以科技光耀善法,成就一良心博客.______________________________________________________________________________________________________ Operating System:UbuntuKylin 16.04 LTS 64bitmysql: Ver 14.14 Distrib 5.7.17, for Linux (

dtgrid 手动条件删除表格中的某一行

dtgrid 手动条件删除表格中的某一行 var grid = $.fn.DtGrid.init(dtGridOption); $(function () { grid.load(); }); function DeleteGood(id,goodName){ layer.confirm('确定删除商品['+goodName+']', { btn: ['确定','取消'], //按钮 shade: false //不显示遮罩 }, function(){ for (var i = 0; i <

jQuery获取动态表格中checkbox被选中一行的属性数据

http://www.jianshu.com/p/0ec66caf4c40 jQuery获取表格中checkbox被选中一行的属性数据

dojo中获取表格中某一行的某个值

dojo中经常出现对表格中的某行进行操作,如单击某行修改.删除等.那怎样获取某行的唯一标示呢? 如查询表格中的某列有个userId,并且这个是唯一的,那么可以通过它来访问这一列 具体操作代码如下: var grid = dijit.byId("gridId"); function btnClick(e) { userId = grid._by_idx[e.rowIndex].item.userId; } dojo.connect(grid,"onRowClick",

js获取表格中的数据 以及 表格中checkbox选中一行数据

前言 不知道是不是大家也遇到过类似的表单,但我绝对是第一次见,如下图所示,表单中包含了表格. 上图中的表格数据是根据数据库中学生表而变化的,这增加了获取表中数据的复杂程度,这里仅仅是记录js如何获取数据传值到后端的办法,所以,仅以表格中张三.李四为例. 示例代码 html <div class="modal-body"> <form id="exam-score-add-form" class="smart-form">