`
eric_hwp
  • 浏览: 125850 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

js创建table以及属性

 
阅读更多

JS动态创建表格(新增、删除行和单元格),动态设置属性,动态添加事件
2009年07月24日 星期五 11:02
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);

     在使用过程中我碰到的一个问题跟大家说一下,就是删除表格的行的时候,如果你删除了某一行,那么表格行数是马上就变化的,所以如果你要删除表格的所有行,下面的代码是错误的:
复制内容到剪贴板代码:
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设置的值了,比如:

  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
  这个方法也全部适用,呵呵。

      C、复合属性

      var objMyTable = document.getElementById("myTable");
      objMyTable.style.cursor = "pointer";

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");

5、添加事件

    A、无参数的情况
    function   doalter(){  
        alert('hi');  
      }  
    var tr = Table.insertRow();
    tr.attachEvent("onclick",doalter);
    或
    tr.setAttribute("onclick","doalter()");
    或
    tr.onclick=function(){doalter();};
    或
    tr.onclick=doalter;

    B、传参数的方法
    var trMouseMove = function(obj)
    {
        return function()
        {
            obj.className='selected';
        }
    }
    var tr = Table.insertRow();
    tr.attachEvent("onmousemove",AddrSelfMouseMove(tr));

 

分享到:
评论

相关推荐

    js动态创建Table

    JavaScript是一种强大的客户端脚本语言,广泛应用于网页交互和动态内容的生成。...以上内容涵盖了JavaScript动态创建Table的基本步骤和相关技术,理解并掌握这些知识点将有助于实现各种复杂的网页交互功能。

    js动态创建table点击按钮dom table tr添加操作

    本主题主要聚焦于如何利用JavaScript动态创建一个包含表格(table)的DOM结构,并且在表格行(tr)中添加可点击的按钮。这通常用于展示数据集,允许用户进行交互操作,比如删除、编辑或查看详情。 首先,我们需要...

    js实现漂亮的table表格

    本教程将详细介绍如何利用JavaScript (JS) 和 Cascading Style Sheets (CSS) 技术来创建一个漂亮且实用的table表格。 **一、HTML基础表格结构** 首先,我们需要在HTML文档中创建基本的表格结构。一个简单的表格由`...

    js的节点操作动态创建table表格,创建行,删除行.pdf

    JavaScript 动态创建 Table 表格和节点操作 根据提供的文件信息,我们可以总结出以下知识点: 1. 节点操作 在 HTML 文档中,所有内容都是节点,包括文档节点、元素节点、文本节点、属性节点和注释节点。节点操作...

    JS手动改变table的宽度

    在网页设计中,JavaScript(JS)是一种常用的客户端脚本语言,用于增强用户的交互体验和动态更新页面内容。本文将深入探讨如何使用JavaScript手动改变HTML表格(table)的宽度,并结合鼠标选中文字查询功能,为用户...

    前台js将table转为Excel表格下载.rar

    综上所述,"前台js将table转为Excel表格下载.rar"中的实现涉及到前端JavaScript技术,包括DOM操作、CSV格式转换、Blob对象以及创建下载链接等步骤,这些知识点对于开发具有数据导出功能的Web应用至关重要。

    JS操作table大全

    本文将深入探讨如何使用JavaScript进行表格的创建、修改、删除以及实现一些特殊效果。 首先,我们从基础开始,创建一个基本的HTML表格。在HTML中,`&lt;table&gt;`元素用于定义表格,`&lt;tr&gt;`表示表格行,`&lt;th&gt;`是表头...

    bootstrap table editable js

    Bootstrap Table Editable JS 是一个基于Bootstrap框架的动态表格插件,它允许用户在表格的单元格内进行编辑,提供了一种交互式的数据展示和管理方式。这个压缩包包含以下三个核心文件: 1. **bootstrap-editable....

    bootstrap-table可编辑下拉框editable js及css及bootstrap-table-editable.js以及使用实例

    这些文件通常包括Bootstrap的核心库、jQuery、bootstrap-table主文件,以及bootstrap-table-editable.js。确保这些资源被正确地链接或导入到HTML文档的`&lt;head&gt;`部分,以便在页面加载时可以正常使用。 以下是一个...

    js 实现 table 行排序 TableOrder.rar

    本资源“js 实现 table 行排序 TableOrder.rar”提供了一个实用的方法来实现这个功能。以下是对该实现的详细说明: 1. **HTML表格结构**: 在HTML中,`&lt;table&gt;`元素用于创建表格,`&lt;tr&gt;`表示表格行,`&lt;th&gt;`表示...

    JS动态创建Table,Tr,Td并赋值的具体实现

    文档展示了通过JavaScript函数getzts()和callback5()来动态生成表格(Table),以及表格的行(Tr)和单元格(Td)。利用DOM操作方法如insertRow()和insertCell(),可以根据条件创建新的行和列,为表格添加新的数据项...

    bootstrap table-js.rar

    5. **功能扩展**:在"bootstrap table-js.rar"中,提到了两个重要的扩展文件:`bootstrap-table-export.js`和`tableExport.js`。这两个文件是用来实现表格数据的导出功能,支持CSV、Excel、PDF等多种格式。引入这两...

    原生js table表格自动排序效果

    总的来说,原生js table表格自动排序效果的实现涉及到HTML结构的理解、JavaScript事件处理、数组排序算法的运用以及DOM操作。这是一个实用的功能,通过学习和理解这个例子,可以提升我们对前端开发中数据处理和交互...

    css+js+table效果代码

    综上所述,【CSS+JS+Table效果代码】是前端开发中的实用技能,结合CSS的样式控制和JS的动态交互,可以创建出功能强大、用户体验良好的数据展示界面。通过分析和学习提供的代码资源,我们可以深入了解并掌握这些技术...

    js 导出table为excel/csv/png/txt/doc文件(支持中文)

    3. **Excel导出**:JavaScript无法直接创建Excel文件,但可以借助库如`xlsx`或` SheetJS`。它们提供API来构造工作簿对象,并将其转换为二进制流。对于中文,需设置正确的字符编码,如`utf8`。 4. **PNG导出**:将...

    JS实现动态修改table及合并单元格的方法示例

    在JavaScript中,动态修改表格(Table)以及合并单元格是常见的需求,特别是在处理数据展示或者报表生成时。以下将详细介绍如何使用JS实现这些功能。 首先,要动态修改表格,我们需要获取表格元素。在HTML中,表格...

    bootstrap-table-fixed-columns.js

    Bootstrap Table 是一个流行的开源JavaScript库,它允许开发者创建功能丰富的响应式表格。"bootstrap-table-fixed-columns.js" 是这个库的一个扩展插件,专门用于处理表格中的固定列问题。在网页设计中,固定列是一...

    JavaScript如何动态创建table表格

    本文将详细介绍两种JavaScript动态创建table表格的方法。 方法一:最原始的方法,通过`createElement()`函数逐个创建元素。这种方法需要手动构建表格的结构,包括`&lt;table&gt;`、`&lt;tbody&gt;`、`&lt;tr&gt;`和`&lt;td&gt;`等元素。例如...

    FileSaver.js用于table导出Excel

    在浏览器的安全限制下,通常不允许直接保存文件到用户的硬盘,但FileSaver.js通过创建一个隐藏的`&lt;a&gt;`标签和模拟点击事件来规避这一限制。当调用`saveAs()`函数时,它会生成一个Blob对象,这个对象包含了要保存的...

    js展现table方法

    本文将深入探讨如何使用JavaScript来动态地创建、操作和展现`&lt;table&gt;`,以及如何结合其他技术,如单点登录(Single Sign-On, SSO)和选项卡切换,来增强用户界面。 首先,让我们关注如何使用JavaScript来创建一个...

Global site tag (gtag.js) - Google Analytics