表格類的原型函數:用於以表格方式表現從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
//=======================================================
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);
僅限於標準表格。