一、动态表格编辑+传值(JS+Servlet)
网上有很多关于如何动态添加表格(行),但是动态表格生成后的传值缺少相关资料,现将自己的体会分享给大家。
1、动态添加表格
代码修改至网上实例,相信大家也可做到!(非重点)
1)对象获取
/**
* @function 根据id值查找对象
* @param thObj id值
* @param theDoc 范围
* @return foundObj id值对应的对象
* @author 李亮
* @date 2011.5.2
* **/
function findObj(theObj, theDoc){
var p, i, foundObj;
if(!theDoc)
theDoc = document;
if( (p = theObj.indexOf("?")) > 0 && parent.frames.length){
theDoc = parent.frames[theObj.substring(p+1)].document;
theObj = theObj.substring(0,p);
}
if(!(foundObj = theDoc[theObj]) && theDoc.all)
foundObj = theDoc.all[theObj];
for (i=0; !foundObj && i < theDoc.forms.length; i++)
foundObj = theDoc.forms[i][theObj];
for(i=0; !foundObj && theDoc.layers && i < theDoc.layers.length; i++)
foundObj = findObj(theObj,theDoc.layers[i].document);
if(!foundObj && document.getElementById)
foundObj = document.getElementById(theObj);
return foundObj;
}
2)添加表格行
/**
* @function 添加鲜土样处理信息
* @param null
* @author 李亮
* @date 2011.5.1
* **/
function AddFreshSoilTableRow(){
//读取最后一行的行号,存放在txtTRLastIndex文本框中
var txtTRLastIndex = findObj("txtTRLastIndex",document);
var rowID = parseInt(txtTRLastIndex.value);
var sampleTable = findObj("sampleTable",document);
//添加行
var newTR = sampleTable.insertRow(sampleTable.rows.length);
newTR.id = "tableTR" + rowID;
newTR.align="center";
//添加列:序号
var newNameTD = newTR.insertCell(0);
//添加列内容
newNameTD.innerHTML = newTR.rowIndex.toString();
//添加列:原始编号
var newYsbhTD=newTR.insertCell(1);
//添加列内容
newYsbhTD.innerHTML = "<input name='txtYsbh' id='txtYsbh' type='text' size='12'/>";
//添加列:统一编号
var newTybhTD=newTR.insertCell(2);
//添加列内容
newTybhTD.innerHTML = "<input name='txtTybh' id='txtTybh' type='text' size='12'/>";
//添加列:实验室编号
var newSysbhTD=newTR.insertCell(3);
//添加列内容
newSysbhTD.innerHTML = "<input name='txtSysbh' id='txtSysbh' type='text' size='12'/>";
//添加列:处理内容
var newClTD=newTR.insertCell(4);
//添加列内容
newClTD.innerHTML = "<input name='txtCl' id='txtCl' type='text' size='12'/>";
//添加列:重复次数
var newCfTD=newTR.insertCell(5);
//添加列内容
newCfTD.innerHTML = "<input name='txtCf' id='txtCf' type='text' size='6'/>";
//添加列:硝态氮
var newXtNTD=newTR.insertCell(6);
//添加列内容
newXtNTD.innerHTML = "<input type='checkbox' name='selAllXtN'/>";
//添加列:铵态氮
var newAtNTD=newTR.insertCell(7);
//添加列内容
newAtNTD.innerHTML = "<input type='checkbox' name='selAllAtN' />";
//添加列:WaterPer
var newWaterPerTD=newTR.insertCell(8);
//添加列内容
newWaterPerTD.innerHTML = "<input type='checkbox' name='selAllWaterPer' id='isWaterPer' />";
//添加删除列操作
var newDeleteTD=newTR.insertCell(9);
//添加列内容
newDeleteTD.innerHTML = "<div align='center' style='width:45px'><input type='button' name='saveSubmit' value='删除' onclick=\"DeleteTableRow('" + newTR.id +"')\"/> </div>";
//将行号推进下一行
txtTRLastIndex.value = (rowID + 1).toString() ;
}
3)删除表格行
/**
* @function 删除指定行
*
* **/
function DeleteTableRow(rowid){
var sampleTable = findObj("sampleTable",document);
//var plantTable = document.get
var tableItem = findObj(rowid,document);
//获取将要删除的行的Index
var rowIndex = tableItem.rowIndex;
//删除指定Index的行
sampleTable.deleteRow(rowIndex);
//重新排列序号,如果没有序号,这一步省略
for(var i=rowIndex;i<sampleTable.rows.length;i++){
sampleTable.rows[i].cells[0].innerHTML = i.toString();
}
}//清空列表
4)JSP or HTML页面代码
<div>
<table width="100%" border="0" cellpadding="2" cellspacing="1" id="sampleTable">
<tr id="trHeader" align="center">
<td width="70" bgcolor="#96E0E2">序号</td>
<td width="109" bgcolor="#96E0E2">原始ID</td>
<td width="109" bgcolor="#96E0E2">统一ID</td>
<td width="109" bgcolor="#96E0E2">实验室ID</td>
<td width="109" bgcolor="#96E0E2">处理内容</td>
<td width="93" bgcolor="#96E0E2">重复次数</td>
<td width="96" bgcolor="#96E0E2" >硝态氮<br /><input type="checkbox" id="selAllXtN" onclick="selectAllBox(this.id);"/></td>
<td width="96" bgcolor="#96E0E2" align="center">铵态氮<br /><input type="checkbox" id="selAllAtN" onclick="selectAllBox(this.id);"/></td>
<td width="96" bgcolor="#96E0E2" align="center">含水率<br /><input type="checkbox" id="selAllWaterPer" onclick="selectAllBox(this.id);"/></td>
<td width="70" bgcolor="#96E0E2">操作</td>
</tr>
</table>
</div>
<div>
<input type="button" name="addSubmit" value="添加" onclick="AddFreshSoilTableRow()" />
<input type="button" name="clearSubmit" value="清空" onclick="ClearAllContent()" />
<input name='txtTRLastIndex' type='hidden' id='txtTRLastIndex' value="1" />
<input type="submit" name="saveSubmit" value="保存" onclick="SaveAllContent()"/>
<input type="text" id="sampleInfo" style="display:none"/>
</div>
2、动态表格传值(重点,原创哦)
不管有没有人这么做过,但是这个方法是我自己想出来的,也是一点点写出来了。或许大家会有更好的方法,如有也请分享一下。
思路:在提交之前,将动态表格中的内容放到一个隐藏的<input style=“display:none” name="tableData" type="text" />中,通过这个统一将表格中的内容传递过去,这个大家都应该很明白什么意思了吧!
注意事项:通过JS向后台传递中文,与用form传递,字符解析方法是不同的。但中文字符传递一定要解析,不让会出现乱码,这一点很重要,网上有相关的资料,这里不再一一陈述。
具体做法(附代码)
1)页面代码
<input type="submit" name="saveSubmit" value="提交" onclick="SaveAllContent()"/>
<input type="text" id="tableData" style="display:none"/>
2)JS代码
/**
* @function 保存表格内容
* @ autor 李亮
*
* **/
function SaveAllContent(){
if(confirm('确定要录入吗?')){
var sampleTable = findObj("sampleTable",document);
var rowsNum = sampleTable.rows.length;
var arr = new Array(rowsNum);
for(var i = 1;i < rowsNum; i++){
var rowId = "tableTR"+i;
var rowTr = findObj(rowId,document);
arr[i-1] = new Array(rowTr.cells.length-1);
for (var j = 1;j < rowTr.cells.length; j++){
if(sampleTable.rows[i].cells[j].children[0].type=="text"){
arr[i-1][j-1] = sampleTable.rows[i].cells[j].children[0].value;
}else if(sampleTable.rows[i].cells[j].children[0].type=="checkbox"){
arr[i-1][j-1] = sampleTable.rows[i].cells[j].children[0].checked;
}else{
arr[i-1][j-1] = "#";
}
}
}
var tableData = findObj("tableData",document);
tableData.value = arr;
}
}
4)后台处理(Java)将字符创转换为二位数组,并用Bean类保存
/**
*
* @param tableDate 页面js生成动态表中 传递过来的表格内容
* @function String类型的tableDate转换为链表存储
* @return ArrayList<FreshSoilBean> 鲜土样信息链表
* @author 李亮
* @date 2011.5.6
* **/
public ArrayList<FreshSoilBean> handFreshSoilTableData(String tableDate){
ArrayList<FreshSoilBean> list = new ArrayList<FreshSoilBean>();
String[] tableRows = tableDate.split("#,");
for(int i=0;i<tableRows.length;i++){
String[] tableCells = tableRows[i].split(",");
for(int j=0;j<tableCells.length;j++){
if(tableCells[j].equals("true"))
tableCells[j]="1";
else if(tableCells[j].equals("false"))
tableCells[j]="0";
}
FreshSoilBean freshSoilBean = new FreshSoilBean();
freshSoilBean.setPrid(tableCells[0]);
freshSoilBean.setUnid(tableCells[1]);
freshSoilBean.setExid(tableCells[2]);
freshSoilBean.setDealContent(tableCells[3]);
freshSoilBean.setEchoNum(tableCells[4]);
freshSoilBean.setIsWaterPer(tableCells[5]);
freshSoilBean.setIsXtN(tableCells[6]);
freshSoilBean.setIsAtN(tableCells[7]);
freshSoilBean.setIsDone("0");
list.add(freshSoilBean);
}
return list;
}
3、小结
以上是我在做实验室数据管理系统的心得,Javascript能够很好的减轻后台数据处理负担,而今天Ajax的应用,让Javascript有了新的活力,也改变了很多人对Javascript的认识。对于想对Javascript有深入的了解童鞋,我强烈建议阅读一下《JavaScrpt 高级程序设计》图灵教育,人民邮电出版社出版。额,后续,我会陆续将我在Javascript其他体会写出来,大概会有Ajax(JavaScript+Servlet)实现案例代码;类万方、知网数据检索的前台实现;Javascript实现Excel导入导出等功能,等等Javascript其他应用。
分享到:
相关推荐
一个优秀的LOGO设计不仅能够吸引人们的注意力,还能在众多竞争者中使你的公司脱颖而出。"公司漂亮的标识LOGO"这个主题强调了设计在商业中的关键作用,尤其是对于提升品牌形象和识别度。 LOGO设计通常包含以下几个...
"银行logo.rar(117个)"这个压缩包文件收集了全国117家银行的官方标志,对于设计、研究、教学或是银行业务了解来说,都是一份非常宝贵的资源。 首先,我们来谈谈银行logo的设计要素。一个优秀的银行logo通常包含以下...
dc machine control using fuzzy logoc
人脸识别项目实战
内容概要:本文详细描述了一个完整的Web应用程序的开发过程。该项目主要采用了Hono作为服务器框架,Prisma作为ORM工具,JWT用于认证鉴权,以及一系列现代化的最佳实践确保系统的健壮性和安全性。项目初期构建了基础架构,并设置了必要的依赖和工具。在后端方面涵盖了公共API接口的设计、CRUD增删改查逻辑、用户认证和授权等功能。此外还特别关注到了API的安全保护,如输入输出的校验,跨站请求伪造CSRF的防范,XSS防御等措施;为确保代码的质量引入了代码检测(比如ESLint搭配Prettier),并建立了完善的测试框架以保障后续开发阶段的功能正确。对于可能出现的问题预先定义了一组规范化的异常响应,并提供OpenAPI文档以方便开发者理解和调用。数据存储层面上利用了关系型与非关系型数据库各自的特性,实现了数据的有效组织,最后提供了实用的脚本,可用于种子数据插入以及执行必要的初始化工作。 适合人群:面向具有一定JavaScript/TypeScript开发经验,尤其是Node.js后台服务搭建经验的中级程序员和技术团队。 使用场景及目标:这份材料非常适合那些需要快速建立安全高效的RES
【资源介绍】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,也可以作为小白实战演练和初期项目立项演示的重要参考借鉴资料。 3、本资源作为“学习资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研和多多调试实践。 掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip掌静脉识别算法源码(门禁).zip
手势识别项目实战
(参考GUI)MATLAB BP的交通标志系统.zip
人脸识别项目实战
内容概要:本文详细介绍了 C++ 函数的基础概念及其实战技巧。内容涵盖了函数的基本结构(定义、声明、调用)、多种参数传递方式(值传递、引用传递、指针传递),各类函数类型(无参无返、有参无返、无参有返、有参有返),以及高级特性(函数重载、函数模板、递归函数)。此外,通过实际案例展示了函数的应用,如统计数组元素频次和实现冒泡排序算法。最后,总结了C++函数的重要性及未来的拓展方向。 适合人群:有一定编程基础的程序员,特别是想要深入了解C++编程特性的开发人员。 使用场景及目标:① 学习C++中函数的定义与调用,掌握参数传递方式;② 掌握不同类型的C++函数及其应用场景;③ 深入理解函数重载、函数模板和递归函数的高级特性;④ 提升实际编程能力,通过实例强化所学知识。 其他说明:文章以循序渐进的方式讲解C++函数的相关知识点,并提供了实际编码练习帮助理解。阅读过程中应当边思考边实践,动手实验有助于更好地吸收知识点。
Comsol光学仿真模型:包括纳米球 柱 Mie散射多级分解 ,Comsol光学仿真模型; 纳米球; 柱; Mie散射; 多级分解,Comsol光学仿真模型:纳米结构Mie散射多级分解
永磁同步电机全速域控制高频方波注入法、滑模观测器法SMO、加权切矢量控制Simulink仿真模型 低速域采用高频方波注入法HF,高速域采用滑膜观测器法SMO,期间采用加权形式切 送前方法 1、零低速域,来用无数字滤波器高频方波注入法, 2.中高速域采用改进的SMO滑模观测器,来用的是sigmoid函数,PLL锁相环 3、转速过渡区域采用加权切法 该仿真各个部分清晰分明,仿真波形效果良好内附详细控制方法资料lunwen 带有参考文献和说明文档,仿真模型 ,核心关键词: 1. 永磁同步电机; 2. 全速域控制; 3. 高频方波注入法; 4. 滑模观测器法SMO; 5. 加权切换矢量控制; 6. Simulink仿真模型; 7. 零低速域控制; 8. 中高速域控制; 9. 转速过渡区域控制; 10. 仿真波形效果; 11. 详细控制方法资料; 12. 参考文献和说明文档。,永磁同步电机多域控制策略的仿真研究
基于蜣螂优化算法的无人机三维路径规划【23年新算法应用】可直接运行 Matlab语言 主要内容:读取地形数据,利用蜣螂算法DBO优化三维路径,目标函数为总路径最短,同时不能撞到障碍物,效果如图所示,包括迭代曲线图、三维路径图、二维平面图等等 ,基于蜣螂优化算法;无人机;三维路径规划;总路径最短;障碍物避免;Matlab语言;迭代曲线图;三维路径图;二维平面图,蜣螂算法优化无人机三维路径规划:实时避障、路径最短新应用
清华大学2024年研究生复试上机考试题.zip
南京理工大学研究生入学考试2011年复试上机试题
手势识别项目实战
这里是3501的内容,用于复习资料
异步电动机变压变频调速系统,包含六千多字的文档、框架图、Simulink仿真模型,电力拖动、电机控制仿真设计 仿真模型+报告 开关闭环对比仿真都有,资料如图所见如所得 ,异步电动机;变压变频调速系统;六千字文档;框架图;Simulink仿真模型;电力拖动;电机控制仿真设计;开闭环对比仿真;资料如图。,异步电机控制仿真系统:六千字详解与图解
人脸识别项目实战
手势识别项目实战