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


Posted in Javascript onOctober 12, 2016

$("#mytable tr").find("td:nth-child(1)") 1表示获取每行的第一列
$("#mytable tr").find("td:nth-child(3)") 3表示获取每行的第三列

今天在项目中,刚好用到给指定的table添加一行、删除一行,就直接找google,搜出来的东西不尽如人意,不是功能不好就是千篇一律,简直浪费时间还不讨好,于是乎就自己动手封装个,现就把代码分享出来,避免大伙重复造轮子,如有问题欢迎大伙拍砖指正,千万可别人身攻击,嘎嘎。。。

需求场景

1)、添加一行

支持在任意行添加一行且可配置的,如可在第一行添加一行、第二行添加一行、倒数第一行添加一行、倒数第二行添加一行,随需求的变化都不会影响。

前提条件:行数需在表中存在否则添加不成功。

2)、删除一行

支持动态删除一行。

先演示结果,如中意了在好好研究代码。

1、原始界面如下:

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

2、添加一行,如要添加一行需点击“添加”按钮,现点击两下会自动添加两行,效果如下截图:

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

3、删除一行,如要删除指定行,先要选中行然后在点击“删除”按钮进行删除(这不是废话嘛~~~),现选中一行,效果如下截图:

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

4、对选中行进行删除,现点击“删除”按钮就会把选中的行删除掉,效果如下截图:

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

代码如下:

<%@ page language="java" pageEncoding="UTF-8"%>
 
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
 <head>
 <title>利用jquery给指定的table添加一行、删除一行</title>
 <meta http-equiv="pragma" content="no-cache">
 <meta http-equiv="cache-control" content="no-cache">
 <meta http-equiv="expires" content="0">
 <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
 <meta http-equiv="description" content="This is my page">
 <script type="text/javascript"
  src="<%=request.getContextPath()%>/js/jquery-1.5.1.js"></script>
 <script type="text/javascript">
 ////////添加一行、删除一行封装方法///////
 /**
  * 为table指定行添加一行
  *
  * tab 表id
  * row 行数,如:0->第一行 1->第二行 -2->倒数第二行 -1->最后一行
  * trHtml 添加行的html代码
  *
  */
 function addTr(tab, row, trHtml){
   //获取table最后一行 $("#tab tr:last")
   //获取table第一行 $("#tab tr").eq(0)
   //获取table倒数第二行 $("#tab tr").eq(-2)
   var $tr=$("#"+tab+" tr").eq(row);
   if($tr.size()==0){
    alert("指定的table id或行数不存在!");
    return;
   }
   $tr.after(trHtml);
 }
  
 function delTr(ckb){
   //获取选中的复选框,然后循环遍历删除
   var ckbs=$("input[name="+ckb+"]:checked");
   if(ckbs.size()==0){
    alert("要删除指定行,需选中要删除的行!");
    return;
   }
      ckbs.each(function(){
       $(this).parent().parent().remove();
      });
 }
  
 /**
  * 全选
  * 
  * allCkb 全选复选框的id
  * items 复选框的name
  */
 function allCheck(allCkb, items){
  $("#"+allCkb).click(function(){
   $('[name='+items+']:checkbox').attr("checked", this.checked );
  });
 }
  
 ////////添加一行、删除一行测试方法///////
 $(function(){
  //全选
  allCheck("allCkb", "ckb");
 });
  
 function addTr2(tab, row){
  var trHtml="<tr align='center'><td width='30%'><input type='checkbox' name='ckb'/></td><td width='30%'>地理</td><td width='30%'>60</td></tr>";
  addTr(tab, row, trHtml);
 }
  
 function delTr2(){
   delTr('ckb');
 }
 </script>
 </head>
 
 <body>
 <table border="1px #ooo" id="tab" cellpadding="0"
  cellspacing="0" width="30%">
  <tr align="center">
    <td width="30%"><input id="allCkb" type="checkbox"/></td>
  <td width="30%">科目</td>
  <td width="30%">成绩</td>
  </tr>
  <tr align="center">
    <td width="30%"></td>
  <td width="30%">语文</td>
  <td width="30%">80</td> 
  </tr>
 </table>
 <input type="button" onclick="addTr2('tab', -1)" value="添加">
   <input type="button" onclick="delTr2()" value="删除">
 
 </body>
</html>

以上就是小编为大家带来的利用jquery给指定的table动态添加一行、删除一行的方法全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
身份证号码前六位所代表的省,市,区, 以及地区编码下载
Apr 12 Javascript
整理一些JavaScript的IE和火狐的兼容性注意事项
Mar 17 Javascript
js写出遮罩层登陆框和对联广告并自动跟随滚动条滚动
Apr 29 Javascript
一个字符串反转函数可实现字符串倒序
Sep 15 Javascript
JavaScript中Number对象的toFixed() 方法详解
Sep 02 Javascript
使用JS实现图片轮播的实例(前后首尾相接)
Sep 21 Javascript
详解Vue-cli3.X使用px2rem遇到的问题
Aug 09 Javascript
layer页面跳转,获取html子节点元素的值方法
Sep 27 Javascript
vue实现顶部菜单栏
Nov 08 Javascript
Echarts在Taro微信小程序开发中的踩坑记录
Nov 09 Javascript
如何使用vue3打造一个物料库
May 08 Vue.js
javascript进阶篇深拷贝实现的四种方式
Jul 07 Javascript
jQuery给指定的table动态添加删除行的操作方法
Oct 12 #Javascript
详解Javascript中的原型OOP
Oct 12 #Javascript
浅析BootStrap Treeview的简单使用
Oct 12 #Javascript
jquery自定义表单验证插件
Oct 12 #Javascript
jquery 动态增加删除行的简单实例(推荐)
Oct 12 #Javascript
老生常谈javascript的类型转换
Oct 12 #Javascript
vue制作加载更多功能的正确打开方式
Oct 12 #Javascript
You might like
PHP简单实现断点续传下载的方法
2015/09/25 PHP
利用PHP命令行模式采集股票趋势信息
2016/08/09 PHP
PHP开发中解决并发问题的几种实现方法分析
2017/11/13 PHP
PHP判断是否是微信打开还是浏览器打开的方法
2019/02/27 PHP
php use和include区别总结
2019/10/13 PHP
js 点击页面其他地方关闭弹出层(示例代码)
2013/12/24 Javascript
删除javascript所创建子节点的方法
2015/05/21 Javascript
浅谈JavaScript中的apply/call/bind和this的使用
2017/02/26 Javascript
vue.js利用Object.defineProperty实现双向绑定
2017/03/09 Javascript
vue 封装自定义组件之tabal列表编辑单元格组件实例代码
2017/09/07 Javascript
使用 UniApp 实现小程序的微信登录功能
2020/06/09 Javascript
[02:56]DOTA2亚洲邀请赛 VG出场战队巡礼
2015/02/07 DOTA
Python抓取Discuz!用户名脚本代码
2013/12/30 Python
python读写LMDB文件的方法
2018/07/02 Python
Python设计模式之状态模式原理与用法详解
2019/01/15 Python
python 实现的发送邮件模板【普通邮件、带附件、带图片邮件】
2019/07/06 Python
python3实现语音转文字(语音识别)和文字转语音(语音合成)
2020/10/14 Python
vue.js刷新当前页面的实例讲解
2020/12/29 Python
Django 实现图片上传和下载功能
2020/12/31 Python
python+opencv3.4.0 实现HOG+SVM行人检测的示例代码
2021/01/28 Python
Matplotlib animation模块实现动态图
2021/02/25 Python
纯HTML5+CSS3制作生日蛋糕(代码易懂)
2016/11/16 HTML / CSS
英国网上香水店:Fragrance Direct
2016/07/20 全球购物
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
UGG雪地靴德国官网:UGG德国
2016/11/19 全球购物
美国花园雕像和家居装饰网上商店:Design Toscano
2019/03/09 全球购物
市优秀教师事迹材料
2014/02/05 职场文书
电气工程及其自动化专业求职信
2014/06/23 职场文书
认真学习保证书
2015/02/26 职场文书
幼儿园园长安全责任书
2015/05/08 职场文书
2016大学生党校学习心得体会
2016/01/06 职场文书
高中语文教材(文学文化常识大全一)
2019/08/13 职场文书
创业计划书之餐饮
2019/09/02 职场文书
Vue的生命周期一起来看看
2022/02/24 Vue.js
MySQL数据库Innodb 引擎实现mvcc锁
2022/05/06 MySQL
Hive日期格式转换方法总结
2022/06/25 数据库