table2csv:将表格转化为csv数据
参数:一个JSON对象
{
'repeatChar':'拆分单元格填充字符', //默认为null则将单元格值填充到拆分的每个单元格中,如果给定字符串则用给定字符串填充
'callback':'回调函数' //传入两个参数(csv,data),分别为csv字符串和data二维数组
}
(function($){ $.fn.table2csv=function(option){ if(option==null) option={}; if(option.repeatChar=='') option.repeatChar="-"; //计算行数列数 var rows=0; //行 var cols=0; //列 this.find("tr").each(function(){ rows+=1; var tr=$(this); var n=tr.find("td,th").length; cols=Math.max(cols,n); }); //document.title=("行/列:"+rows+"/"+cols); //空数组准备 var data=new Array(); for(var i=0;i<rows;i++){ var line=new Array(); for(var j=0;j<cols;j++) line.push(''); data.push(line); } //数据填充 var i=0;//当前行坐标 this.find("tr").each(function(){ var tr=$(this); var j=0;//当前列坐标 tr.find("td,th").each(function(){ var td=$(this); var colspan=1; var rowspan=1; var value=td.text(); if(td.attr("colspan")!=null) colspan=parseInt(td.attr("colspan")); if(td.attr("rowspan")!=null) rowspan=parseInt(td.attr("rowspan")); //定位CSV数组中第一个没有数据的单元格 for(var p=0;p<data[i].length;p++){ if(data[i][p]==''){ j=p; break; } } data[i][j]=value;//填充值 if(colspan+rowspan==2) return; //如果不是合并单元格,返回并继续each //填充单元格区域 var fic=i+rowspan; //alert(value+i+":"+j); for(var fi=i;fi<fic;fi++){ var fjc=j+colspan; //alert(""+j+"\r\n"+fic+":"+fjc); for(var fj=j;fj<fjc;fj++){ if((fj==j)&&(fi==i)) continue; data[fi][fj]= (option.repeatChar==null)? value :option.repeatChar; //alert(test(data)); } } }); i++; }); //填充完毕 //生成调试数据 var str=""; for(var i in data){ str+=data[i].join(","); str+="\r\n"; } if(option.callback!=null) option.callback(str,data); }; ///////////////////////////////// $.fn.csv2table=function(param){ var isarray=param instanceof Array; var data=null; if(isarray)//数组直接用 data=param; else{//csv字符串则转为数组 data=new Array(); var lines=param.split('\r\n'); for(var i=0;i<lines.length;i++){ var cells=lines[i].split(','); data.push(cells); } } var table="<table border='1'>"; for(var i=0;i<data.length;i++){ table+="<tr>"; var cells=data[i]; for(var j=0;j<cells.length;j++) table+=("<td>"+cells[j]+"</td>"); table+="</tr>"; } table+="</table>"; table+=(isarray?"<!--数组-->":"<!--字串-->"); this.html(table); } })(jQuery);
测试界面(将表格中的内容转为csv,然后再将csv生成为第二个表格):
jQuery Table2CSV插件(表格转CSV) 完美支持colspan和rowspan的更多相关文章
-
JS table内容转成二维数组,支持colspan和rowspan
思路:1.先初始化colspan的数据到数组2.根据rowspan和colspan计算th和td的矩阵二次填充数组 说明:需要引用到第三方库jQuery,table中的th和td行和列跨度必须正确 & ...
-
推荐10款 好用的 Jquery 评分插件
Raty jQuery Raty这是一个能够自动生成可定制的星级评分jQuery插件.可以自定义图标,创建各种评级组合,星星数量,每一颗星星的注释,可以在当一个星星被点击时的加回调函数. 地址: Ra ...
-
jquery水印插件:placeholder
jquery水印插件:placeholder 有的浏览器支持html5的水印placeholder(如Crome,firefox,ie10+),有的不支持html5的placeholder(ie9,i ...
-
使用jQuery.form插件,实现完美的表单异步提交
传送门:异步编程系列目录…… 时间真快,转眼一个月快结束了,一个月没写博客了!手开始生了,怎么开始呢…… 示例下载:使用jQuery.form插件,实现完美的表单异步提交.rar 月份的尾巴,今天的主 ...
-
Perfect Scrollbar – 完美的 jQuery 滚动条插件
Perfect Scrollbar 是一个很小的,但完美的 jQuery 滚动插件.滚动条不会影响原来的设计布局,滚动条的设计是完全可定制的.你可以改变几乎所有的 CSS 样式的滚动条,滚动条设计对脚 ...
-
AudioPlayer.js,一个响应式且支持触摸操作的jquery音频插件
AudioPlayer.js是一个响应式.支持触摸操作的HTML5 的音乐播放器.本文是对其官网的说用说明文档得翻译,博主第一次翻译外文.不到之处还请谅解.之处. JS文件地址:http://osva ...
-
jquery银行电子账单表格填入和编辑插件
jquery银行电子账单表格填入和编辑 前段时间做的一个银行表格账单的jquery插件,用于金额写入和编辑的应用,希望对大家有所帮助,发现问题欢迎回复 ;(function($){ function ...
-
15 个最佳的 jQuery 布局插件【转】
英文原文:15 Best jQuery Grid Plugins for Developers 现如今,网站开发设计的需求会要求自动适应所有移动设备,即响应式网站: 在开发网站时必须考虑对平板设备融合 ...
-
[jQuery]jQuery DataTables插件自定义Ajax分页实现
前言 昨天在博客园的博问上帮一位园友解决了一个问题,我觉得有必要记录一下,万一有人也遇上了呢. 问题描述 园友是做前端的,产品经理要求他使用jQuery DataTables插件显示一个列表,要实现分 ...
随机推荐
-
十一、C# 泛型
为了促进代码重用,尤其是算法的重用,C#支持一个名为泛型的特性. 泛型与模块类相似. 泛型使算法和模式只需要实现一交.而不必为每个类型都实现一次.在实例化的时候,传入相应的数据类型便可. 注:可空值类 ...
-
无线功率 mW 和 dBm 的换算
无线电发射机输出的射频信号,通过馈线(电缆)输送到天线,由天线以电磁波形式辐射出去.电磁波到达接收地点后,由天线接收下来(仅仅接收很小很小一部分功率),并通过馈线送到无线电接收机.因此在无线网络的工程 ...
-
Arduino 跷跷板(2016-01-04)
前言这是参加社区活动,用赠送的 LilyPad 来做小实验,也体验了一把艺术的LilyPad!本来是申请 nano 的,不知道怎么的就出错啦,申请成 LilyPad 了,这个实验应该用 nano 比较 ...
-
SURF 特征法
public static void FindMatch(Mat modelImage, Mat observedImage, out long matchTime, out VectorOfKeyP ...
-
跨主机使用 Rex-Ray volume - 每天5分钟玩转 Docker 容器技术(77)
上一节我们在 docker1 上的 MySQL 容器中使用了 Rex-Ray volume mysqldata,更新了数据库.现在容器已经删除,今天将演示在 docker2 中重新使用这个卷. 在 d ...
-
微信小程序滚动动画,点击事件及评分星星制作!
前言 小程序上线刷爆了朋友圈,但是最近渐渐消沉了,很少有动静!最近公司项目需要,体验了一下微信小程序,制作了几个功能,布局感觉很简单,但是交互和动画等写起来确实很费劲,主要是因为他不能操作DOM,只能 ...
-
启动eclipse时候提示错误Error:Could not create the Java Virtual Machine. Error:A Fatal exception has occurred,Program will exit.
我的是neon3版本 解决办法是: 首先把这两个选项勾选,才能看到eclipse.ini完整的文件名.然后用记事本等工具打开编辑. 新版的里面原本是这样: -startup plugins/org.e ...
-
查看mac系统版本
打开终端, 输入命令 uname -a 回车 x86_64 表示系统为64位 i686 表示系统32位的
-
NodeJS对象数组Array 根据对象object key的值排序sort
有个js对象数组 var ary=[{id:1,name:”b”},{id:2,name:”b”}] 需求是根据name 或者 id的值来排序,这里有个风骚的函数. /** * 对数组中的对象,按对象 ...
-
bzoj 2936 [Poi 1999] 降水 - 并查集
题目传送门 需要root权限的传送门 题目大意 有一个$n\times m$的网格图,每一格都有一个高度.一次降雨过后问最多能积多少水. 考虑算每一高度能储存的水的量. 如果小于等于这个高度的格子和边 ...