论坛交流
首页办公自动化| 网页制作| 平面设计| 动画制作| 数据库开发| 程序设计| 全部视频教程
应用视频: Windows | Word2007 | Excel2007 | PowerPoint2007 | Dreamweaver 8 | Fireworks 8 | Flash 8 | Photoshop cs | CorelDraw 12
编程视频: C语言视频教程 | HTML | Div+Css布局 | Javascript | Access数据库 | Asp | Sql Server数据库Asp.net  | Flash AS
当前位置 > 文字教程 > Javascript教程
Tag:验证,特效,入门,实例,验证,表单,特效,正则表达式,跑马灯,document,函数,代码,getElementByID,菜单,图片,视频教程

javascript代码创建表格类

文章类别:Javascript | 发表日期:2009-8-5 10:34:55

javascript代码创建表格类


http://bizhi.knowsky.com/
var DataTable = function(tableTitles, tableValues,alignDirect)
{
    var table = document.createElement("table");
    var tbody = document.createElement("tbody");
    table.appendChild(tbody);
   
    if (alignDirect == 0)         //Columns Mode
    {
        var nColumns = tableTitles.length;
        var nRows = tableValues.length + 1;
        for (var i = 0; i < nRows; i++)
        {
            tbody.insertRow(i);
            for (var j = 0; j < nColumns; j++)
            {
                tbody.rows[i].insertCell(j);
                if (i == 0)
                {
                    tbody.rows[i].cells[j].appendChild(tableTitles[j]);
                }
                else
                {
                    tbody.rows[i].cells[j].appendChild(tableValues[i-1][j]);
                }
            }
        }
    }
    else                        //Rows Mode
    {
        var nRows = tableTitles.length;
        var nColumns = tableValues.length + 1;
        for(var i = 0; i < nRows; i++)
        {
            tbody.insertRow(i);
            for (var j = 0; j < nColumns; j++)
            {
                tbody.rows[i].insertCell(j);
                //tbody.rows[i].cells[j].setAttribute("align", "left");
                if (j == 0)
                {
                    tbody.rows[i].cells[j].appendChild(tableTitles[i]);
                }
                else
                {
                    tbody.rows[i].cells[j].appendChild(tableValues[j-1][i]);
                }
            }
        }
    }
    return table;
}

当调用这个类时,需要的参数包括表示表格表头(相当于ColumnNames)的一维数组和表示表格数据的二维数组(相当于DataTable)以及表格的排列方式(纵排或者横排)作为参数传递近来,然后该类可以返回一个Table对象,在html中则可以直接附加(appendChild)这个Table了。
调用示例:
var ColumnNames = new Array();
var TableValues = new Array(DataColumn[1], DataColumn[2], ...);//DataColumn[i] is a One Dimension Array.
var table = new DataTable(ColumnNames, TableValues, 1);
table.className = "cssClass";// a css style class.
div.appendChild(table);

效果不错,省了很多事,避免了每次写table。不过仅限于标准表格。:)

表格类的原型函数:用于以表格方式表现从xml中读取的数据
//-------------------------------------------------------
//   Yang Xiaodong
//   IRSA, CAS
//-------------------------------------------------------
//Class     :DataTable
//Purpose   :provides a table class
//-------------------------------------------------------
//Calls     :None
//Called by :None
//-------------------------------------------------------
//Arguments :tableTitles    the Column or Row titles of table
//           tableValues    A 2 dimension Array to represent values in table
//           alignDirect    the title align direct of table, 0 is horizontal or titles in coloumns, 1 is vertical or titles in rows
//Globals   :None
//Returns   :table element
//-------------------------------------------------------
//Notes     :None
//-------------------------------------------------------
//History   :2007/10/27  1.0
//=======================================================
上一篇:{教程}js中缩略图功能的实现 人气:2543
下一篇:IE和Firefox浏览器下JS的不同点 人气:2456
视频教程列表
文章教程搜索
 
Javascript推荐教程
Javascript热门教程
看全部视频教程
购买方式/价格
购买视频教程: 咨询客服
tel:15972130058