搜索
查看
编辑修改
首页
UNITY
NODEJS
PYTHON
AI
GIT
PHP
GO
CEF3
JAVA
HTML
CSS
搜索
凡人多烦事01
这个屌丝很懒,什么也没留下!
关注作者
热门标签
jquery
HTML
CSS
PHP
ASP
PYTHON
GO
AI
C
C++
C#
PHOTOSHOP
UNITY
iOS
android
vue
xml
爬虫
SEO
LINUX
WINDOWS
JAVA
MFC
CEF3
CAD
NODEJS
GIT
Pyppeteer
article
热门文章
1
算法:哈希表_哈希表算法
2
浏览器输入框有时候会显示很多搜索记录,不知道怎么删除_删除搜索框内一条记录
3
基于单片机的新型消防车系统(设计报告+开题中期报告+电路原理图+程序)_基于stm32智能喷水小车毕业论文
4
网络相关指令_ARP表,Route表,Mac表_路由表查看
5
n-gram语言模型——句子概率分布计算与平滑_编写平滑函数完成数据平滑,利用平滑数据完成对2-gram模型的建立,计算测试句子概率
6
2020最新各大厂面试遇到的100道软件测试面试题+答案纯干货!! 金九银十到了 快点看!!!(二)_2020年最新大厂软件测试面试
7
Android组件化学习,《Android面试题及解析》分享_安卓 组件化的缺点
8
用LLama-Factory训练和微调 LLama3,打造你的专属 AI 模型!
9
鸿蒙开发之网络请求_鸿蒙开发网络请求
10
极简风个人学术网站完全指南 Jekyll+Github Page+Minimal Mistakes_个人学术主页网站
当前位置:
article
> 正文
javascript动态创建表格:新增、删除行和列_js实现excel sheet表的新增逻辑
作者:凡人多烦事01 | 2024-06-03 21:18:34
赞
踩
js实现excel sheet表的新增逻辑
利用js来动态创建表格有两种格式,appendChild()和insertRow、insertCell()。两种方式其实差不多,但第一种有可能在IE上有问题,所以推荐大家使用第二种了,直接说吧。
1、inserRow()和insertCell()函数
insertRow()函数可以带参数,形式如下:
insertRow(index):index从0开始
这个函数将新行添加到index的那一行前,比如insertRow(0),是将新行添加到第一行之前。默认的insertRow()函数相当于insertRow(-1),将新行添加到表的最后。一般我们在使用的时候都是:objTable.insertRow(objTable.rows.length).就是为表格objTable在最后新增一行。
insertCell()和insertRow的用法相同,这里就不再说了。
2、deleteRow()和deleteCell()方法
deleteRow()函数可以带参数,形式如下:deleteRow(index):index从0开始
和上面两个方法差不多的意思,就是删除指定位置的行和单元格。要传入的参数:Index是行在表格中的位置,可以下面的方法取得然后去删除:
var row=document.getElementById("行的Id");
var index=row.rowIndex;//有这个属性,嘿嘿
objTable.deleteRow(index);
另外也可以通过document.getElementById("行的Id").removeNode();来进行删除
在使用过程中我碰到的一个问题跟大家说一下,就是删除表格的行的时候,如果你删除了某一行,那么表格行数是马上就变化的,所以如果你要删除表格的所有行,下面的代码是错误的:
function clearRow(){
objTable= document.getElementById("myTable");
for( var i=1; i<objTable.rows.length ; i++ )
{
tblObj.deleteRow(i);
}
}
这段代码要删除原来的表格的表体,有两个问题。首先不能是deleteRow(i),应该是deleteRow(1)。因为在删除表格行的时候,表格的行数在变化,这就是问题的关键,rows.length总是在变小,删除的行数总是会比预想的要少一半,所以正确的删除表格的行的代码应该这样:
function clearRow(){
objTable= document.getElementById("myTable");
var length= objTable.rows.length ;
for( var i=1; i<length; i++ )
{
objTable.deleteRow(i);
}
}
3、动态设置单元格与行的属性
A、采用setAttribute()方法,格式如下:setAttribute(属性,属性值)
说明:这个方法几乎所有的DOM对象都可以使用,第一个参数是属性的名称,比如说:border,第二个就是你要为border设置的值了,比如:1
var objMyTable = document.getElementById("myTable");
objMyTable.setAttribute("border",1);//为表格设置边框为1
其他的比如你要为一个TD设置高度,同样先取得这个TD对象,然后使用setAttribute()方法
var objCell = document.getElementById("myCell");
objCell.setAttribute("height",24);//为单元格设置高度为24
在使用的时候遇到一个设置样式的问题,不能用setAttribute("class","inputbox2");而应该使用setAttribute("className","inputbox2"),呵呵,其他我估计也有同样的问题,有些属性和我们在DW里面的不一致,呵呵,大家自己摸索吧。
B、直接赋值
var objMyTable = document.getElementById("myTable");
objMyTable.border=1;//为表格设置边框为1
这个方法也全部适用,呵呵。
4、创建表格
了解了行<tr>与单元格<td>的增删那就可以创建表格了。
第一步:你需要有一个你去动态变化的表格,我这里讲的是已经存在页面的表格,我们要设置一个id:myTable
var objMyTable = document.getElementById("myTable");
第二步:创建行与列的对象
var index = objMyTable.rows.length-1;
var nextRow = objMyTable.insertRow(index);//要新增的行,我这里是从倒数第二行开始新增的
//单元格箱号
var newCellCartonNo = nextRow.insertCell();
var cartonNoName = "IptCartonNo";
newCellCartonNo.innerHTML = " <input type=’text’ size=’5’ name="+cartonNoName+" id="+cartonNoName+" value=’’>";
newCellCartonNo.setAttribute("className","tablerdd");
这样就搞定了,可以简单的创建一个行和列了。具体的代码我贴在下面。只是很简单的例子,不过方法就大概是上面的了,呵呵,慢慢摸索吧~
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>蓝光-BlueShine</title>
<script language="JavaScript">
var Count=false,NO=1;
function addRow(){
Count=!Count;
//添加一行
var newTr = testTbl.insertRow(testTbl.rows.length);
//添加两列
var newTd0 = newTr.insertCell();
var newTd1 = newTr.insertCell();
var newTd2 = newTr.insertCell();
//设置列内容和属性
if(Count){newTr.style.background="#FFE1FF";}
else {newTr.style.background="#FFEFD5";}
newTd0.innerHTML = ’<input type=checkbox id="box4">’;
NO++
newTd1.innerText="第"+ NO+"行";
}
</script>
</head>
<body>
<table width="399" border=0 cellspacing="1" id="testTbl" style="font-size:14px;" >
<tr bgcolor="#FFEFD5">
<td width=6%><input type=checkbox id="box1"></td>
<td >第1行</td>
<td > </td>
</tr>
</table>
<label>
<input type="button" value="插入行" οnclick="addRow()" />
</label>
</body>
</html>
5、appendChild()方法
我就直接贴代码了,大家去研究,时间紧,哈哈,见谅~
<html>
<head>
<title>My Test Page</title>
<script type="text/javascript">
<!--
var textNumber = 1;
function addTextBox(form, afterElement) {
// Increment the textbox number
textNumber++;
// Create the label
var label = document.createElement("label");
// Create the textbox
var textField = document.createElement("input");
textField.setAttribute("type","text");
textField.setAttribute("name","txt"+textNumber);
textField.setAttribute("id","txt"+textNumber);
// Add the label’s text
label.appendChild(document.createTextNode("Text Box #"+textNumber+": "));
// Put the textbox inside
label.appendChild(textField);
// Add it all to the form
form.insertBefore(label,afterElement);
return false;
}
function removeTextBox(form) {
if (textNumber > 1) { // If there’s more than one text box
// Remove the last one added
form.removeChild(document.getElementById("txt"+textNumber).parentNode);
textNumber--;
}
}
//-->
</script>
<style type="text/css">
<!--
label {
display:block;
margin:.25em 0em;
}
-->
</style>
</head>
<body>
<form id="myForm" method="get" action="./" />
<label>Text Box #1: <input type="text" name="txt1" id="txt1" /></label>
<p>
<input type="button" value="Add Textbox" οnclick="addTextBox(this.form,this.parentNode)" />
<input type="button" value="Remove Textbox" οnclick="removeTextBox(this.form)" />
</p>
<p><input type="Submit" value="Submit" /></p>
</form>
</body>
</html>
<html>
<head>
<title>My Test Page</title>
<script type="text/javascript">
<!--
var textNumber = 1;
function addTextBox(form, afterElement) {
// Increment the textbox number
textNumber++;
// Create the label
var label = document.createElement("label");
// Create the textbox
var textField = document.createElement("input");
textField.setAttribute("type","text");
textField.setAttribute("name","txt"+textNumber);
textField.setAttribute("id","txt"+textNumber);
// Add the label’s text
label.appendChild(document.createTextNode("Text Box #"+textNumber+": "));
// Put the textbox inside
label.appendChild(textField);
// Add it all to the form
form.insertBefore(label,afterElement);
return false;
}
function removeTextBox(form) {
if (textNumber > 1) { // If there’s more than one text box
// Remove the last one added
form.removeChild(document.getElementById("txt"+textNumber).parentNode);
textNumber--;
}
}
//-->
</script>
<style type="text/css">
<!--
label {
display:block;
margin:.25em 0em;
}
-->
</style>
</head>
<body>
<form id="myForm" method="get" action="./" />
<label>Text Box #1: <input type="text" name="txt1" id="txt1" /></label>
<p>
<input type="button" value="Add Textbox" οnclick="addTextBox(this.form,this.parentNode)" />
<input type="button" value="Remove Textbox" οnclick="removeTextBox(this.form)" />
</p>
<p><input type="Submit" value="Submit" /></p>
</form>
</body>
</html>
声明:
本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:
https://www.wpsshop.cn/w/凡人多烦事01/article/detail/668978
推荐阅读
article
JavaScript
-
获取
手机
验证码
_js
获取
手机
验证码
...
[详细]
-->
赞
踩
article
JavaScript
-
计算器
...
[详细]
-->
赞
踩
article
JavaScript
-
滑动
条_
javascript
滑动
条...
[详细]
-->
赞
踩
article
JavaScript
-缓动
动画
...
[详细]
-->
赞
踩
article
JavaScript
-评论回复
_
删除
_
发表
_
显示
时间
_
js
留言
板
显示
留言
时间
...
[详细]
-->
赞
踩
article
用
Python
编写
网络
爬虫
:从
网页
获取数据
并存储到
Excel
文件...
通过本篇博客,我们学习了如何使
用
Python
编写一个简单的
网络
爬虫
,
用
于从
网页
中提取数据,并将这些数据存储到 Exc...
赞
踩
article
vscode
占用
内存
和
cpu
太高?几招帮你解决!_
vscode
跑项目
node
.js javascri...
欢迎关注前端小讴的github,阅读更多原创技术文章作为前端开发人员,几乎每个人都会用到
vscode
——免费、开源、跨平...
赞
踩
article
vue
内存溢出(
FATAL
ERROR
:
CALL
_AND_
RETRY
_LAST Allocatio...
vscode
开发,启动或重新加载项目,报内存溢出解决办法错误信息如下解决方案全局安装increase-
memory
-li...
赞
踩
article
【
前端
系列
】p
npm
与
npm
:现代
JavaScript
包
管理工具
的
比较...
【
前端
系列
】p
npm
与
npm
:现代
JavaScript
包
管理工具
的
比较 ...
赞
踩
article
react
.js项目npm run
build
报错(Ineffective
mark
-compact...
查了好久,才发现弄错了重点,这里报错的关键提示是:Ineffective
mark
-
compacts
near
heap
...
赞
踩
article
node
打包内存不足问题解决方式:Allocation
failed
-
JavaScript
he...
问题:详细报错内容:FATAL ERROR: Ineffective mark-compacts near
heap
l...
赞
踩
article
create
-
react
-app运行报错:
JavaScript
heap
out
of memor...
背景:
create
-
react
-app搭建
react
项目,默认使用最新版本,
react
@18.0.2.自行改为17.0...
赞
踩
article
react
打包
内存
溢出
----
javaScript
heap
out of
memory
_reac...
package.
js
on中增加这个配置--max-old-space-size=4096_
react
前端
打包
js
栈...
赞
踩
article
react
项目内存溢出,加大内存的方式之一
Ineffective
mark
-
compacts
ne...
FATAL ERROR:
Ineffective
mark
-
compacts
near
heap
limit Alloc...
赞
踩
article
解决 VUE
项目
运行过程报错
JAVASCRIPT
HEAP
OUT OF
MEMORY
(内存溢出...
若是无法全局替换 node_modules 文件的 "%_prog%" 需要暂时删除红框部分,替换完再添加上。你是不是也...
赞
踩
article
Ineffective
mark
-
compacts
near
heap
limit
Allocati...
最近运行公司一个项目时,出现内存溢出 js stacktrace的问题,在这记录一下解决方案全局安装 increase-...
赞
踩
article
Vue打包
内存
溢出-二种方法(
FATAL
ERROR
: Reached
heap
limit
Al...
【代码】Vue打包
内存
溢出-二种方法(
FATAL
ERROR
: Reached
heap
limit
Allocati...
赞
踩
article
JavaScript
if
...
Else 语句_isjqjiirdf
if
,∵...
<!-- 通常在写代码时,您总是需要为不同的决定来执行不同的动作。您可以在代码中使用条件语句来完成该任务。在 J...
赞
踩
article
Javascript
if
语句
使用详解_
js
if
...
分析:我们之前学会用“document.write()”来输出结果,这次我们给大家介绍一种对话框的方式,那就是使用ale...
赞
踩
article
JavaScript
if
语句
_js
if
语句
...
在程序中
if
语句
属于条件
语句
的一种。如同
if
的本意,就是根据条件做不同的事情。_js
if
语句
js
if
语句
...
赞
踩
相关标签
javascript
前端
开发语言
css3
css
动画
html
python
爬虫
前端开发
vscode
cpu
内存
vue
vue.js
npm
node.js