Js实现Table动态添加一行的小例子
<form id="form1" runat="server">
<div>
<table id="orderTable" border='' cellpadding="" cellspacing="" style="border-collapse: collapse; border-color:#C0C0C0;" rules="none" width="80%" align="center">
<thead>
<tr>
<th style="width: 20%;">申报部门</th>
<th style="width: 20%;">街镇</th>
<th style="width: 20%;">路段名称</th>
<th style="width: 30%;">起止路名</th>
<th>操作</th>
</tr>
</thead>
<tr id="row0">
<td>
<select id="UrbanDepNo0" name="UrbanDepNo" style="width:90%">
<option value="">三林城管署</option>
<option value="">港城城管署</option>
<option value="">惠南城管署</option>
<option value="">金桥城管署</option>
<option value="">陆家嘴城管办</option>
<option value="">川沙城管署</option>
</select>
</td>
<td>
<input type="text" id="LocNo0" name="LocNo" style="width:90%"/> </td>
<td>
<input type="text" id="RoadSectionName0" name="RoadSectionName" style="width:90%"/>
</td>
<td>
<input type="text" id="StStartRoad0" name="StStartRoad" style="width:45%"/>--
<input type="text" id="EndRoadName0" name="EndRoadName" style="width:45%"/>
</td>
<td>
<input type="button" name="delete" value="删 除" style="width:80px" onclick="deleteSelectedRow(0)" /> </td>
</tr>
<tr>
<td align="center" colspan="">
<br />
<input type="button" name="insert" value="增加一行" style="width:80px" onclick="insertNewRow()" />  
<input type="button" value=" 保 存 " style="width:80px" onclick="GetValue()" />
</td>
</tr>
</table>
</div>
<div style="MARGIN: 40px auto;">
<table id="TableInfo" border='' cellpadding="" cellspacing="" style="border-collapse: collapse; border-color:#C0C0C0;" width="80%" align="center">
<tr>
<td align="center">
申报部门
</td>
<td align="center">
街镇
</td>
<td align="center">
路段名称
</td>
<td align="center">
起止路名
</td>
<td align="center">
操作
</td>
</tr>
</table>
</div>
</form> <script src="jquery.min.js" type="text/javascript"></script>
<script type="text/javascript" language='javascript'>
//声明全局变量
var formvalue = "";
var flag = ;
var index = ;
var firstCell = "";
var secondCell = "";
var thirdCell = "";
var fourthCell = ""; $(function() {
//初始化第一行
firstCell = $("#row0 td:eq(0)").html();
secondCell = $("#row0 td:eq(1)").html();
thirdCell = $("#row0 td:eq(2)").html();
fourthCell = $("#row0 td:eq(3)").html();
}); //-----------------新增一行-----------start--------------- function insertNewRow() {
//获取表格有多少行
var rowLength = $("#orderTable tr").length;
//这里的rowId就是row加上标志位的组合。是每新增一行的tr的id。
var rowId = "row" + flag; //每次往下标为flag+1的下面添加tr,因为append是往标签内追加。所以用 after
var insertStr = "<tr id=" + rowId + ">" + "<td style='width: 20%'>" + firstCell + "</td>" + "<td style='width: 20%'>" + secondCell + "</td>" + "<td style='width: 20%'>" + thirdCell + "</td>" + "<td style='width: 30%'>" + fourthCell + "</td>" + "<td><input type='button' name='delete' value='删除' style='width:80px' onclick='deleteSelectedRow(\"" + rowId + "\")' />"; + "</tr>";
//这里的行数减2,是因为要减去底部的一行和顶部的一行,剩下的为开始要插入行的索引
$("#orderTable tr:eq(" + (rowLength - ) + ")").after(insertStr); //将新拼接的一行插入到当前行的下面
//为新添加的行里面的控件添加新的id属性。
$("#" + rowId + " td:eq(0)").children().eq().attr("id", "UrbanDepNo" + flag);
$("#" + rowId + " td:eq(1)").children().eq().attr("id", "LocNo" + flag);
$("#" + rowId + " td:eq(2)").children().eq().attr("id", "RoadSectionName" + flag);
$("#" + rowId + " td:eq(3)").children().eq().attr("id", "StStartRoad" + flag);
$("#" + rowId + " td:eq(3)").children().eq().attr("id", "EndRoad" + flag);
//每插入一行,flag自增一次
flag++;
} //-----------------删除一行,根据行ID删除-start-------- function deleteSelectedRow(rowID) {
if (confirm("确定删除该行吗?")) {
$("#" + rowID).remove();
}
}
//-----------------获取表单中的值----start-------------- function GetValue() {
var value = "";
$("#orderTable tr").each(function(i) {
if (i >= ) {
$(this).children().each(function(j) {
if ($("#orderTable tr").eq(i).children().length - != j) {
value += $(this).children().eq().val() + "," //获取每个单元格里的第一个控件的值
if ($(this).children().length > ) {
value += $(this).children().eq().val() + "," //如果单元格里有两个控件,获取第二个控件的值
}
}
});
value = value.substr(, value.length - ) + "#"; //每个单元格的数据以“,”分割,每行数据以“#”号分割
}
});
value = value.substr(, value.length);
ReceiveValue(value);
// $("#formvalue").val(value);
// $("formvalue").submit();
}
//-------------------接收表单中的值----------------------------- function ReceiveValue(str) {
var Str = str.split('#');
if (Str[] != "") {
for (var i = ; i < Str.length - ; i++) {
var value = Str[i].split(',');
var dept = value[];
var street = value[]
var section = value[];
var Broad = value[];
var Eroad = value[];
insertTable(dept, street, section, Broad, Eroad);
$("input[type='text']").val("");
$("select[name='UrbanDepNo']").val("");
}
}
} //---------------将表单中的数据添加到新表中--------------------- function insertTable(dept, street, section, Broad, Eroad) {
var department = "";
switch (dept) {
case "":
department = "三林城管署";
break;
case "":
department = "港城城管署";
break;
case "":
department = "惠南城管署";
break;
case "":
department = "金桥城管署";
break;
case "":
department = "陆家嘴城管办";
break;
case "":
department = "川沙城管署";
break;
default:
break;
} //将接收到数据添加到新表TableInfo中。
$('#TableInfo').append("<tr id=" + index + "><td align='center'>" + department + "</td> <td align='center'>" + street + "</td><td align='center'>" + section + "</td> <td align='center'>" + Broad + "-" + Eroad + "</td> <td align='center'><a href='#' onclick='deltr(" + index + ")'>删 除</a></td></tr>");
index++;
} //----------新表中的删除方法----------- function deltr(index) {
if (confirm("确定删除吗?")) {
$("tr[id='" + index + "']").remove();
}
}
</script>
Js实现Table动态添加一行的小例子的更多相关文章
- 利用jquery给指定的table动态添加一行、删除一行
转自:http://www.cnblogs.com/linjiqin/p/3148181.html $("#mytable tr").find("td:nth-child ...
- 利用jquery给指定的table动态添加一行、删除一行,复制,值不重复等操作
$("#mytable tr").find("td:nth-child(1)") 1表示获取每行的第一列$("#mytable tr").f ...
- ASP.NET给Table动态添加删除行,并且得到控件的值
ASP.NET给Table动态添加控件并且得到控件的值 由于跟老师做一个小的项目,可是我自己又不太懂js,所以一直为动态建立表格并且能动态的取值和赋值感到苦恼.起初在网上找到了一些js资源,解决了动态 ...
- js对select动态添加和删除OPTION
<select id="ddlResourceType" onchange="getvalue(this)"> </select> 动态 ...
- JS对select动态添加options操作[IE&FireFox兼容]
<select id="ddlResourceType" onchange="getvalue(this)"> </select> 动态 ...
- 使用js对select动态添加和删除OPTION示例代码
动态删除select中的所有options.某一项option以及动态添加select中的项option,在IE和FireFox都能测试成功,感兴趣的朋友可以参考下,希望对大家有所帮助 <s ...
- 使用js对select动态添加和删除OPTION
<select id="ddlResourceType" onchange="getvalue(this)"> </select> 动态 ...
- JS对select动态添加option操作 (三级联动) (搜索拼接)
以下纯属自我理解之下再东搜西查的内容~ JS对select动态添加option操作有个高大上的艺名叫多级联动:第一级改变时,第二级跟着变,第二级改变时,第三级跟着变... 本菜鸟是在工作中遇到做收货地 ...
- 浅谈js中如何动态添加表头/表列/表格内容
我想很多童鞋用js动态向表格中添加数据很熟悉,而且也觉得非常简单!是的,对于写页面的童鞋来说,最喜欢写查询的页面了,动态向表格绑定数据.用for循环就可以轻松搞定. 如果我们的业务需求有所变化,可能我 ...
随机推荐
- ES6新特性:使用export和import实现模块化(转载)
在ES6前, 前端就使用RequireJS或者seaJS实现模块化, requireJS是基于AMD规范的模块化库, 而像seaJS是基于CMD规范的模块化库, 两者都是为了为了推广前端模块化的工 ...
- python---读取/写入excel用例数据
使用excel管理用例 ①.读取excel的用例数据,每一类参数保存在list中返回:②.那么接下来使用unitest编写用例时,可以去调用这个函数.使用里面的数据: 个人认为好处是,大部分人还是习惯 ...
- Codeforces 986D Perfect Encoding FFT 分治 高精度
原文链接https://www.cnblogs.com/zhouzhendong/p/9161557.html 题目传送门 - Codeforces 986D 题意 给定一个数 $n(n\leq 10 ...
- JavaWeb 之Ubuntu intelliJ 新建maven项目及配置tomcat
一. 破解安装 intelliJ 下载网址:https://www.jetbrains.com/idea/ 破解激活:https://www.cnblogs.com/tanrong/p/7309343 ...
- Java中System类的相关应用
1.Runtime: public class RuntimeDemo { public static void main(String[] args) { Runtime runtime=Runti ...
- HDU 5178 pairs【二分】||【尺取】
<题目链接> 题目大意: 给定一个整数序列,求出绝对值小于等于k的有序对个数. 解题分析: $O(nlong(n))$的二分很好写,这里就不解释了.本题尺取$O(n)$也能做,并且效率很不 ...
- POJ 2155 Matrix 【二维树状数组】(二维单点查询经典题)
<题目链接> 题目大意: 给出一个初始值全为0的矩阵,对其进行两个操作. 1.给出一个子矩阵的左上角和右上角坐标,这两个坐标所代表的矩阵内0变成1,1变成0. 2.查询某个坐标的点的值. ...
- HDU4578 Transformation【线段树】
<题目链接> <转载于 >>> > 题目大意: 有一个序列,有四种操作: 1:区间[l,r]内的数全部加c. 2:区间[l,r]内的数全部乘c. 3:区间[l ...
- HTTP STATUS CODE: 521的解决办法
https://blog.csdn.net/wangdepei/article/details/84798601
- weblogic domain creation
管理服务器 URL: http://CICI-ThinkPad:7001 Domain Path: D:\Program Files\DEV\Oracle\Middleware\user_projec ...