刚刚不知道怎么回事,CSDN博客一直打不开,就在博客园完毕了今天的记录,结果临关机,登录了下。发现又好了,就再多花个几分钟转下吧,也无论到底在意的是什么了,权当强迫症了...

前几天记录了动态的加入一行一列:insertRow()和insertCell();动态的删除一行一列:deleteRow()和deleteCell();选中一行:this的參数传递,这些都是实现的关键,可是这一切都建立在一个基础上:那就是存在一个表格。今天就来记录下动态建立表格的方法:

其实在刚開始的时候。我仅仅想到了一个方法,尽管到最后发现这种方法确实还是比較简单的,就像是动态加入行和列一样,整合起来不就是一个表格了么:

来看一下编写的代码,同一时候还发现了它的生成方式:(这里在html页面上留了一个tableTest的div)

1 window.onload=function createTable1() {
2 var table = document.createElement('table');
3 for (var i = 0; i < 4; i++) {
4 var row = table.insertRow();
5 for (var j = 0; j < 2; j++) {
6 var cell = row.insertCell();
7 cell.innerHTML = "这里是"+i +"行" +',' + j+"列";
8 }
9 }
10 document.getElementById('tableTest').appendChild(table);
11 table.setAttribute('border', '1');
12 }

这样来看一下生成的效果:

这里可看到了吧,他是从下向上生成的行,从右向左生成的列。也就意味着。插入一行之后。再进行插入的话,是在其上方插入行,在左边插入列,后来从网上搜索了之后,原来还有好多方法,当然各种应用各有千秋。这里简单写一下其他两种方式:

1、生成元素

看代码的生成步骤:

 1  window.onload=function createTable2() {
2 var table = document.createElement('table');
3 var tbody = document.createElement('tbody');
4 for (var i = 0; i < 4; i++) {
5 var tr = document.createElement('tr');
6 for (var j = 0; j < 2; j++) {
7 var td = document.createElement('td');
8 var inner = document.createTextNode("这个是"+i +"行"+ ',' + j+"列");
9 td.appendChild(inner);
10 tr.appendChild(td);
11 }
12 tbody.appendChild(tr);
13 }
14 table.appendChild(tbody);
15 document.getElementById('tableTest').appendChild(table);
16 table.setAttribute('border', '1');
17 }

这样再来看一下效果的话:

这个就是从上到下,从左到右的生成了吧。这个的话尽管理解上简单,可是写法上也比較麻烦呢。

2、数组编辑(拼接html语言)

看代码的实现步骤:

1 window.onload= function createTable4() {
2 var arr = new Array();
3 arr.push('<table border=1><tbody>');
4 for (var i = 0; i < 4; i++) {
5 arr.push('<tr>');
6 for (var j = 0; j < 3; j++) {
7 arr.push('<td>' +"这里是"+ i +"行"+ ',' + j +"列"+ '</td>');
8 }
9 arr.push('</tr>');
10 }
11 arr.push('</tbody><table>');
12
13 document.getElementById('tableTest').innerHTML = arr.join('');
14 }

这时候来看效果的话:

这个理解起来就更简单了,就算是把Array改成字符串拼接的话。我们可能理解的更清晰些,就跟在html语言里面加入一样吧,这样写起来最easy理解,可是确实有些啰嗦了。

其实看到代码的时候。确实自己就能明确该怎样是怎么实现的加入。可是最開始想到动态加入的时候,却仅仅想到了近期在研究的方法,就有点不周全了。今天開始补牙。还是有点害怕补牙啊,感觉好恐怖....

这花了三分钟再把博客园上写好的转到这里来,是一种执念么,还是一种矫情。哎,睡觉。天有些晚了...

js动态创建表格------Day59的更多相关文章

  1. js动态创建表格,删除行列的小例子

    js动态创建表格,删除行列的实例代码. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" &quo ...

  2. js动态创建表格

    <!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...

  3. js动态创建表格方法

    window.onload = function(){ var table = document.createElement('table'); table.border = 1; table.wid ...

  4. js 动态生成表格案例

    <1>布局:一个table表格,表格分为两个部分,上面是thead表头,表头里面仅一行,有4列(th),   下面是tbody表格内容,要求tbody中的每一行都是用js动态创建的 < ...

  5. js/jq动态创建表格的行与列

    之前做了一个项目,需求是能动态创建表格行,动态创建表格的列,度了很多资料,都没有动态创建列的插件,所以自己动手写了一个 需求大概是(下图) 1.动态添加一行.2.动态添加一列,3.删除行.4.删除列, ...

  6. js如何动态创建表格(两种方法)

    js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...

  7. 第84天:jQuery动态创建表格

    jQuery动态创建表格 <!DOCTYPE html> <html lang="en"> <head> <meta charset=&q ...

  8. jquery动态创建表格

    1.代码实例 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  9. javascript动态创建表格:新增、删除行和列

    转载:http://www.cnblogs.com/pato/archive/2009/09/02/1559068.html 利用js来动态创建表格有两种格式,appendChild()和insert ...

随机推荐

  1. selenium3 + python - expected_conditions判断元素

    expected_conditions 类 title_is: 判断当前页面的title是否完全等于(==)预期字符串,返回布尔值 title_contains : 判断当前页面的title是否包含预 ...

  2. python3+request接口自动化框架中自动发送邮件

    在上一篇中的自动化框架中没有放上自动发送测试结果到邮箱的功能,在这篇文章中在补一下,哈哈 1.上一篇的代码就不在一一介绍了,本篇只介绍发送邮件的功能代码 2.在public common 文件夹中创建 ...

  3. 【POJ2248、LOJ#10021】 Addition Chains

    事先预警:由于我太蒻了,本做法只能在POJ.LOJ等小数据(N<=100)平台上通过,在UVa(洛谷)上大数据并不能通过 戳我获得更好的观看效果 本题不用看,爆搜就是了,但是纯爆搜显然会爆时间, ...

  4. CSS命名规则和如何命名

    CSS命名规则 头:header 内容:content/containe 尾:footer 导航:nav 侧栏:sidebar 栏目:column 页面外围控制整体布局宽度:wrapper 左右中:l ...

  5. checked、disabled在原生、jquery、vue下不同写法

          以下是原生和jquery <!DOCTYPE html> <html> <head> <meta http-equiv="Content ...

  6. 【Oracle】解决oracle sqlplus 中上下左右backspace不能用

    一. 解决输入 BACKSPACE 键变成 ^h 的问题 #su - oracle   $stty erase ^h. 要永久生效,可以加入到用户环境配置文件.bash_profile中(vi .ba ...

  7. SQL Server存储过程作业(三)

    阶段4:练习——插入入住客人记录 需求说明 使用存储过程将入住客人信息插入客人信息表中,要求: 检查身份证号必须是18个字符组成 押金的默认值为1000元 如果客人记录插入成功,输出客人流水号:否则输 ...

  8. dubbo之负载均衡

    在集群负载均衡时,Dubbo提供了多种均衡策略,缺省为random随机调用. Random LoadBalance 随机,按权重设置随机概率. 在一个截面上碰撞的概率高,但调用量越大分布越均匀,而且按 ...

  9. Window8.1下安装Matplotlib库

    有两种方法: 直接选用一些预打包库软件,如WinPython, Python(x,y), Enthought Canopy, or Continuum Anaconda.这些软件中已包含有Matplo ...

  10. 【sqli-labs】 less17 POST - Update Query- Error Based - String (基于错误的更新查询POST注入)

    这是一个重置密码界面,查看源码可以看到username作了防注入处理 逻辑是先通过用户名查出数据,在进行密码的update操作 所以要先知道用户名,实际情况中可以注册用户然后实行攻击,这里先用admi ...