javascript - 为什么创建多行多列的表格最后只有一行内有表格
问题描述
我自己写了一个函数,用来创建多行多列的表格,但是写完发现只能创建一行多列。
<p id='game-box'></p> <script> var Tab=createGrids(16,10); var gameBox=document.getElementById('game-box'); gameBox.appendChild(Tab); // 创建网格 function createGrids(row,col) {var Tab=document.createElement('table');var Tbody=document.createElement('tbody');var i=0,j=0;while(i<row) { var Tr=document.createElement('tr'); while(j<col) {var Td=document.createElement('td');Tr.appendChild(Td);j++; } Tbody.appendChild(Tr); i++;}Tab.appendChild(Tbody);return Tab; } </script>
问题解答
回答1:因为你第一遍运行 while(i<row) 的结束时候 while(j<col)中的 j 已经是10了哦,所以,第二遍循环 i以后,创建的tr里面都是没有 td 的,因为没有走进while(j<col) 嘛,
你可以改成这样子
<p id='game-box'></p> <script> var Tab=createGrids(16,10); var gameBox=document.getElementById('game-box'); gameBox.appendChild(Tab); // 创建网格 function createGrids(row,col) {var Tab=document.createElement('table');var Tbody=document.createElement('tbody');var i=0;while(i<row) { var Tr=document.createElement('tr'); var j=0; while(j<col) {var Td=document.createElement('td');Tr.appendChild(Td);j++; } Tbody.appendChild(Tr); i++;}Tab.appendChild(Tbody);return Tab; } </script>
应该就可以了
相关文章:
1. docker images显示的镜像过多,狗眼被亮瞎了,怎么办?2. 大家好,请问在python脚本中怎么用virtualenv激活指定的环境?3. Matlab和Python编程相似吗,有两种都学过的人可以说说吗4. 请教各位大佬,浏览器点 提交实例为什么没有反应5. javascript - Html5做移到端定位,获取授权拒绝了怎么办?6. 网页爬虫 - 用Python3的requests库模拟登陆Bilibili总是提示验证码错误怎么办?7. android - QQ物联,视频通话8. javascript - 关于audio标签暂停的问题9. javascript - 微信小程序封装定位问题(封装异步并可能多次请求)10. javascript - Web微信聊天输入框解决方案
