`

JavaScript动态添加表格行(使用模板、标记)

 
阅读更多
引用:
http://www.soaspx.com/dotnet/ajax/javascript/javascript_20091023_1266.html

在客户端使用JavaScript动态添加表格行,先到网上找了相关的资料,发现有现成做好的组件,发现它只能够满足比较简单的要求,对于复杂的操作情况,比如:添加一行之后,在这一行上还要进行相关的操作会显得有些吃力;本人比较喜欢表现层使用模板、标记填充数据的做法,于是自己做手做了个小组件,与大家一起分享。

组件运行截图:





设计思路:
  在Table的thead中加入一行隐藏的行,当要添加一行时,复制一次隐藏的行,再将实例数据填充到这一行中相应的位置,填充完毕之后,再将这一行加到表格中去,整个操作完成。
模板:隐藏的行即相当于模板,当需要时复制一次模板。
标记:将模板行复制出来后,该如何填充数据?
  网上比较多的组件的做法是,传递进来两个数组,一组是元素名称列表,一组是对应的值列表,然后对复制出来的行进行一个查找,发现其中的元素的名称在元素名称列表中的,让其value=对应的值。这样做可以满足一般的需求,因为Table里面一般放置文本框,将值放到其中即完成任务。对于复杂的情况,要求将数据填充到其它的位置,这种方法就力不从心了。
  我的做法是将复制进来的模板行看做一段String,在这段String中查找标记,再将数据填充到相应的标记中去,这样的话,无论你哪个地方要填充数据,只要放一个标记就可以了,比上面的做法要灵活很多。

代码实现(关键点讲解)
  我定义的标志为${属性},传递过去的数据为一个entity,当在String中发现${city},则表示将entity.city的内容替换${city},当entity.city为NULL时,用 替换${city}( 网页中的空格)。  1动态添加行方法
2function addInstanceRow(tableId,names,values,functionName){
3    var tableObj=getTargetControl(tableId);
4    var tbodyOnlineEdit=getTableTbody(tableObj);
5    var theadOnlineEdit=tableObj.getElementsByTagName("THEAD")[0];
6    var elm=theadOnlineEdit.rows[theadOnlineEdit.rows.length-1].cloneNode(true);
7    elm.style.display="";
8    if(typeof(names)!="undefined"){
9        if(typeof(functionName)=="undefined") functionName="setObjValueByName";
10        if(typeof(values)!="undefined"&&values!=null){
11            var entity=ArrayToObj(names,values);
12            setInputValue(elm,entity,functionName);
13        }
14        else
15            setInputValue(elm,names,functionName);
16    }
17    tbodyOnlineEdit.appendChild(elm);
18}


1,获取Tbody,新添加的行要加到这里面去
  var tbodyOnlineEdit=getTableTbody(tableObj);

2,获取THEAD,隐藏的模板在这里面,进行复制
  var theadOnlineEdit=tableObj.getElementsByTagName("THEAD")[0];
  var elm=theadOnlineEdit.rows[theadOnlineEdit.rows.length-1].cloneNode(true);
  elm.style.display="";

3,去复制出来的行进行填充  1    if(typeof(names)!="undefined"){
2        if(typeof(functionName)=="undefined") functionName="setObjValueByName";
3        if(typeof(values)!="undefined"&&values!=null){
4            var entity=ArrayToObj(names,values);
5            setInputValue(elm,entity,functionName);
6        }
7        else
8            setInputValue(elm,names,functionName);
9    }


4,将填充好数据的行添加到表格中去
  tbodyOnlineEdit.appendChild(elm);

难点、易出问题点说明

1, 获取Tbody,ie与firefox有区别,ie在默认的情况下是为table加上tbody的,而firefox则没有,所以要进行相应的判断
1//得到table中的tbody控件,注意兼容firefox
2function getTableTbody(tableObj){
3    var tbodyOnlineEdit=tableObj.getElementsByTagName("TBODY")[0];
4    if(typeof(tbodyOnlineEdit)=="undefined"||tbodyOnlineEdit==null){
5        tbodyOnlineEdit=document.createElement("tbody");
6        tableObj.appendChild(tbodyOnlineEdit);
7    }
8    return tbodyOnlineEdit;
9}


2, 进行填充时,实现了两种情况,一种用根据元素的name,别一种则是根据标记填充
1// 动态添加表格行
2// functionname为“setObjValueByName”为根据元素name,
3//要求names为元素名称,value为相对应的值
4//                                           
5//functionname为“”为标记填充
6//要求names为一个对象,value为null
7function addInstanceRow(tableId,names,values,functionName)
 


3, 进行标志的填充时,使用正则表达式进行标记的查找,找到标记后到entity中取相应的属性的值,取出属性的值之后,要用 替换字符串中的空格,不然显示时会有问题,当属性值为空时用 替换标记符号,代码在以下函数中。  1//根据标志设置添加值
2function setObjValueByFlag(obj,entity){
3    var objTemp=obj.parentNode;
4    var arrMatches=objTemp.innerHTML.match(/\${\w+}/g);
5    if(typeof(arrMatches)=="undefined"||arrMatches==null||typeof(arrMatches.length)=="undefined"||arrMatches.length==null)
6        return;
7    var tempValue="";
8    var propertyValue="";
9    for(var i=0;i<arrMatches.length;i++){
10        tempValue=arrMatches[i].replace(/\${|}/g,"");
11        propertyValue=getEntityPropertyValue(entity,tempValue);
12        if(propertyValue!=null){
13            if(typeof(propertyValue)=="string"){
14                if(propertyValue!="")
15                    propertyValue=propertyValue.replace(/\s/g,"&nbsp;");
16                else
17                    propertyValue="&nbsp;";
18            }   
19            objTemp.innerHTML=objTemp.innerHTML.replace(arrMatches[i],propertyValue);  
20        }
21        else{
22            objTemp.innerHTML=objTemp.innerHTML.replace(arrMatches[i],"&nbsp;");
23        }
24    }
25}

4, 对于填充标志的做法,刚开始的思路是,直接将模板行中的tr下的内容当成文本进行标志的替换,但是显示时没有内容,于是只能逐个把td中的内容对标志进行替换,发现显示时是正确的,这个地方使我有点困惑。很明显前者的做法效率更高,却莫名其妙地显不出来,只能退而求其次了。

函数调用说明  1//见上面说明,这是添加行最基本的对外函数   
2function addInstanceRow(tableId,names,values,functionName)
3   
4//添加实体列表添加表格中,有几个entity则添加几行
5//tableId    要动态添加行的Table的ID值
6//entityList 对象数组 Array类型,
7function addRowByEntityList(tableId,entityList)
8
9//将一个实体添加到一行
10function addRowByEntity(tableId,entity)
11
12//删除触发事件控件所在的行
13function deleteThisRow(targetControl)
14
15//删除表格下的所有行
16function deleteAllRow(tableId)
17


分享到:
评论

相关推荐

    JavaScript 动态添加表格行 使用模板、标记

    设计思路: 在Table的thead中加入一行隐藏的行,当要添加一行时,复制一次隐藏的行,再将实例数据填充到这一行中相应的位置,填充完毕之后,再将这一行加到表格中去,整个操作完成。 模板:隐藏的行即相当于模板,当...

    tabletop_to_leaflet:使用Tabletop将数据从Google电子表格转换为Leaflet的模板

    打开js / script.js文件,然后将您的电子表格ID添加为电子表格_key变量的值。 然后,将“ lat_column”和“ long_column”重命名为表中调用的任何纬度和经度列。 外挂程式 您还可以在地图上使用。 一个示例是,该将...

    leafy:Leafy是一种易于使用的模板,旨在将您的Google电子表格转换为网站上样式可排序的表格

    绿叶 Leafy是一个易于使用的模板,...访问我在创建的google电子表格模板。 复制电子表格并将其保存到您自己的Google驱动器中。 使用您自己的数据编辑电子表格。 您可以扩展或删除类别数。 在“链接”列下输入URL,或

    400个DreamWeaver插件

    mxp/使一个多行的表格行和行之间颜色交替,像斑马线一样。2.0版本 mxp/可以倒出-倒入站点信息,方便其他开发者 mxp/插入e-Vue MPEG-4格式的文件 mxp/Mycomputer.com提供的一套Banner交换系统,使用起来需要注册,...

    attendance-tracker:使用短信跟踪课堂出勤情况并使用谷歌电子表格显示

    使用的技术Javascript、Node、Google Apps 脚本、AngularJS、Mongoose (MongoDB)、Express 路由器、Twilio文件结构分解app/models - 数据库中使用的猫鼬模式公共 - 管理视图来管理电话号码和考勤标记。 使用 ...

    Java语言基础下载

    模板标记 673 内容总结 676 独立实践 676 第三十四章:Hibernate基础 677 学习目标 677 Hibernate简介 678 建立简单的Hibernate应用 678 通过 Hibernate API 操纵数据库 684 Hibernate的初始化 687 访问Hibernate的...

    The-University-of-Melbourne-Web-Templates:为墨尔本大学创建的Web模板。 实施细节如下

    固定表格标记以符合可访问性准则 ##全球化更改(集中应用) 删除了翻译小部件,等待免责声明批准 修改了配色方案以确保符合WCAG 2.0 AA 添加了IE6 / 7表CSS支持 修复了媒体查询中文本会覆盖徽标

    leaflet-storymaps-with-google-sheets:滚动驱动的故事地图,使用Leaflet和jQuery在GeoJSON中带有点标记和叙述文本

    带有Google表格的传单故事图使用链接的Google表格模板和滚动叙述自定义您的Leaflet故事地图。 支持图像,音频和视频嵌入以及Leaflet TileLayer / geojson叠加层。实时链接(替换为您自己的链接) 传单地图 Google...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part1

    实例038 动态输出JavaScript代码 69 实例039 当数字遇到了字符串 70 实例040 PHP程序员的基础——变量的应用 72 实例041 打印系统环境变量信息print_r($_ENV) 73 实例042 使用可变变量输出“I Like PHP!” 73 实例...

    PHP开发实战1200例(第1卷).(清华出版.潘凯华.刘中华).part2

    实例038 动态输出JavaScript代码 69 实例039 当数字遇到了字符串 70 实例040 PHP程序员的基础——变量的应用 72 实例041 打印系统环境变量信息print_r($_ENV) 73 实例042 使用可变变量输出“I Like PHP!” 73 实例...

    ProjetExtractVisuConnaissances

    点标记根据缩放级别动态聚类。 单击点簇将放大底层要素的范围。 将鼠标悬停在该点上将显示名称。 单击将显示一个弹出窗口,其中列/属性显示为 html 表。 使用预先输入的全文过滤 完全客户端 javascript,包含...

    前端三剑客参考文档大全.zip

    JavaScript是一种脚本语言,其源代码在发往客户端运行之前不需经过编译,而是将文本格式的字符代码发送给浏览器由浏览器解释运行它可以在网页上实现复杂的功能,网页展现给你的不再是简单的静态信息,而是实时的内容...

    Trilha-Alura-Front-end:Alura Trail前端

    阿鲁拉前端步道 借助HTML,CSS,JavaScript,从零开始到成功的...POST-标记的模板文字 站点-Alura Live:JavaScript ALURA + JavaScript中的类和函数 课程-JavaScript:编程对象定向 ALURA + JS林特 PODCAST-JavaScri

    simplecontactform:用于原型制作的简单联系表

    这个包应该给你一个简单的联系表格的基本标记。 尽管它是每个联系表格的良好基础,因此请随意使用它作为基础。 ##Installation 在 Meteor 应用程序目录中添加包: $ meteor add chaosbohne:simplecontactform ##...

    PHP和MySQL Web开发第4版pdf以及源码

    1.4 添加动态内容 1.4.1 调用函数 1.4.2 使用date()函数 1.5 访问表单变量 1.5.1 简短、中等以及长风格的表单变量 1.5.2 字符串的连接 1.5.3 变量和文本 1.6 理解标识符 1.7 检查变量类型 1.7.1 PHP的数据...

    PHP和MySQL Web开发第4版

    1.4 添加动态内容 1.4.1 调用函数 1.4.2 使用date()函数 1.5 访问表单变量 1.5.1 简短、中等以及长风格的表单变量 1.5.2 字符串的连接 1.5.3 变量和文本 1.6 理解标识符 1.7 检查变量类型 1.7.1 PHP的数据...

    PHP和MySQL WEB开发(第4版)

    1.4 添加动态内容 1.4.1 调用函数 1.4.2 使用date()函数 1.5 访问表单变量 1.5.1 简短、中等以及长风格的表单变量 1.5.2 字符串的连接 1.5.3 变量和文本 1.6 理解标识符 1.7 检查变量类型 1.7.1 PHP的数据类型 1.7.2...

    静态工匠

    (Laravel Blade模板) 托管: CMS: 图片托管: 联系表格: 谷歌分析动态元标记(SEO,Facebook Open Graph,Twitter卡) 帖子可以有多个标签帖子可能过时(超过365天)会显示警告代码高亮显示: 共享按钮: 评论:...

Global site tag (gtag.js) - Google Analytics