利用jquery动态添加和删除表格的一行,并且保存单行数据
开发时遇到一个需求:要求要在页面的表格可以添加和删除一行,并能填写对应的数据后保存这一行数据。
HTML代码
界面使用了freemarker框架,teams是后台传过来的list类型数据
<form action="" id="" method="post">
...
<table id="addTable" >
<tr class="first_tr">
<th>姓名</th>
<th>国籍</th>
<th>单位</th>
<th>职务</th>
<th>专业、特长</th>
<th>操作</th>
</tr>
<#list teams as item>
<tr>
<input type="hidden" id="id" value="${item.id!}"/>
<td>${item.name!}</td>
<td>${item.gj!}</td>
<td>${item.dw!}</td>
<td>${item.zw!}</td>
<td>${item.zytc!}</td>
<td><input type="button" onclick="delRow(this)" value="-删除"/></td>
</tr>
</#list>
</table>
<table>
<tr>
<td celspan="6">
<input type="button" onclick="addRow()" value="+添加"/>
</td>
</tr>
</table>
...
</form>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
为了不提交表格模板,我把模板放在了form表单外面,并且样式设置为不可见
需要添加的表格模板:
<table style="display: none" id="tbl" >
<tr class="will80">
<td><input type="text" id="name" name="name" /></td>
<td><input type="text" id="gj" name="gj" /></td>
<td><input type="text" id="dw" name="dw" /></td>
<td><input type="text" id="zw" name="zw" /></td>
<td><input type="text" id="zytc" name="zytc"/></td>
<td></td>
//新增的表格中需要有保存和删除操作
<td><input type="button" onclick="save(this)" value="保存"/><input type="button" onclick="delRow(this)" value="-删除"/></td>
</tr>
</table>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
主要靠jquery代码,实现为#addTable添加最后一行
原理就是获取id为“tbl”的一行复制添加到id为“addTable”的最后一行。
保存这一行数据使用ajax。
jQuery代码
添加表格行
function addRow(){
var targetTbody= $("#tbl tbody");
//获取#tbl表格的最后一行
var tr = targetTbody.children("tr:last");
//复制到#addTable表格最后
var tr2=$("#addTable tbody").children("tr:last");
tr2.after(tr[0].outerHTML);
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
删除表格行
function delRow(obj){
//获取当前对象的父元素,在其下寻找id为“id”的元素的值
var id1=$(obj).parents("tr").find("#id").val();
var res=confirm("确定要删除么?");
if(res){
//删除界面元素,当前行
$(obj).parents("tr").remove();
}
//若有id就表示该数据是界面原本就有的,需要删除数据库数据
//若无id表示为界面动态添加的,删除时只需要删除界面元素
if(id1!=null){
//ajax删除数据
$.ajax({
url : "suggestpage_delTeam.do",
data : {"id":id1},
type : "POST",
success : function(data) {
if (data == "true") {
alert("删除成功");
} else {
alert(data);
}
}
});
}
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
保存单行数据
function save(obj) {
var param = {};
//获取当前属性
param.projectId="${proId}";
param.name = $(obj).parents("tr").find("#name").val();
param.gj = $(obj).parents("tr").find("#gj").val();
param.dw =$(obj).parents("tr").find("#dw").val();
param.zw = $(obj).parents("tr").find("#zw").val();
param.zytc = $(obj).parents("tr").find("#zytc").val();
//判空校验
if(checkNull(obj)){
//保存数据
$.ajax({
url : "suggestpage_savePeople.do",
ontentType : "application/x-www-form-urlencoded; charset=UTF-8",
data : param,
type : "POST",
success : function(data) {
if (data == "true") {
alert("保存成功");
//跳转界面
window.location="part2.do?proId="+param.projectId;
} else {
alert(data);
}
}
});
}
}
//判空校验
function checkNewNull(obj){
var ok=true;
//获取新增的input
var newtr=$(obj).parents("tr").find("input");
newtr.each(function(){
if($(this).val()==""){
alert("请将表单填写完整!");
$(this).focus();
ok=false;
return false;
}
});
return ok;
}
利用jquery动态添加和删除表格的一行,并且保存单行数据的更多相关文章
- jQuery动态添加和删除表格行
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
- jquery 动态添加和删除 ul li列表
今天需要实现一个jquery动态添加和删除 ul li列表中的li行,自己简单的实现乐一个,分享一下 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...
- 利用jQuery动态添加input输入框,并且获取他的值
动态添加 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEnco ...
- jQuery动态添加、删除按钮及input输入框
输入框的加减实现: <html> <head> <meta charset="utf-8"> <title>动态创建按钮</t ...
- jQuery 动态添加、删除css样式
1.addClass css中: <style type="text/css"> .chColor {background: #267cb7;color:w ...
- jQuery动态添加删除select项
// 添加 function col_add() { var selObj = $("#mySelect"); var value="value"; var t ...
- jQuery如何动态添加具有删除按钮的行
代码实例如下: <!DOCTYPE html><html><head><meta charset=" utf-8"><meta ...
- jquery 动态添加表格行
jquery 动态添加表格行 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <h ...
- jquery动态添加删除div--事件绑定,对象克隆
我想做一个可以动态添加删除div的功能.中间遇到一个问题,最后在manong123.com开发文摘 版主的热心帮助下解答了(答案在最后) 使用到的jquery方法和思想就是:事件的绑定和销毁(unbi ...
随机推荐
- Django基础之视图(views)层、模板层
目录 Django基础之视图(views)层.模板层 JsonResponse 向前端返回一个json格式字符串的两种方式 重写Django中的json的某个方法 form表单上传文件 FBV与CBV ...
- Java小程序—录屏小程序(下半场)
下半场. 上半场,我们我们写了录屏的程序,那么下半场我们的任务是写一个播放器. 设计思路:播放器的思路就是将图片放在一个JScrollPane中顺序播放,所以还是得使用swing组件,并且仍然要使用线 ...
- DockerFile 编译语法详解
Dockerfile是一个文本格式的配置文件,用户可以使用Dockerfile来快速创建自定义的镜像,本小结首先介绍Dockerfile典型的基本结构和它支持的众多指令,并具体讲解通过这些指令来编写定 ...
- c# 简单打开关闭摄像头
const short WM_CAP = 1024; const int WM_CAP_DRIVER_CONNECT = WM_CAP + 10; const int WM_CAP_DRIVER_DI ...
- Git复习(十三)之git revert用法及与git reset区别
git revert用法以及与git reset的区别 git revert用法 git revert 撤销 某次操作,此次操作之前和之后的commit和history都会保留,并且把这次撤销 作为一 ...
- ArcGis之popup列表字段自定义
ArcGis之popup列表字段自定义 featureLayer图层中可以使用popupTemplate属性添加弹窗. API:https://developers.arcgis.com/javasc ...
- python 练习合集一
一.运算符与流程控制 1.输入两个整数,打印较大的那个值2.输入三个整数,按照从小到大的顺序打印3.输入一个三位数,打印其个位.十位.百位上的数4.输入一个年份,判断是否为闰年,是打印一句话,不是打印 ...
- 转载:mysql数据库连接自动断开
转自:https://www.cnblogs.com/ay-a/p/10520425.html MySql连接空闲8小时自动断开引起的问题 一.问题描述 最近遇到了一个奇怪的MySql数据库问 ...
- redis blog
IBM 看到的blog如何 存储在redis种 var ArticleHelper = function () { this.ArticleIDSet = "AIDSet"; // ...
- epoll机制和简述
在linux的网络编程中,很长的时间都在使用select来做事件触发.在linux新的内核中,有了一种替换它的机制,就是epoll.相比于select,epoll最大的好处在于它不会随着监听fd数目的 ...