首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >使用Javascript创建HTML表

使用Javascript创建HTML表
EN

Stack Overflow用户
提问于 2013-04-21 07:36:25
回答 3查看 157.9K关注 0票数 23

我的问题最终将与这个网站相关:

http://dbtest.net16.net/ethanol-01.html

编辑:在此处查看未加密的页面源代码>>> http://dbtest.net16.net/ethanol-22.html

这是一个使用JavaScript计算结果的超文本标记语言表单。我的目标是显示一个表的2-6列和可变数量的行取决于用户的输入(形式将被修改)。我的问题是,在用户单击Calculate按钮后,我不能完全理解如何在JavaScript中创建表。我已经找到了一些潜在的好答案,但显然还没有完全理解。运行下面的代码有点像我想要显示的输出。

代码语言:javascript
复制
<html>
    <!-- http://www.java2s.com/Tutorial/JavaScript/0220__Array/OutputarrayelementinaHTMLtableformat.htm -->

    <head>
        <title>Table of Numbers</title>
    </head>

    <body>
         <h1>Table of Numbers</h1>

        <table border="0">
            <script language="javascript" type="text/javascript">
                <!--

                var myArray = new Array();
                myArray[0] = 1;
                myArray[1] = 2.218;
                myArray[2] = 33;
                myArray[3] = 114.94;
                myArray[4] = 5;
                myArray[5] = 33;
                myArray[6] = 114.980;
                myArray[7] = 5;

                document.write("<tr><td style='width: 100px; color: red;'>Col Head 1</td>");
                document.write("<td style='width: 100px; color: red; text-align: right;'>Col Head 2</td>");
                document.write("<td style='width: 100px; color: red; text-align: right;'>Col Head 3</td></tr>");

                document.write("<tr><td style='width: 100px;'>---------------</td>");
                document.write("<td style='width: 100px; text-align: right;'>---------------</td>");
                document.write("<td style='width: 100px; text-align: right;'>---------------</td></tr>");

                for (var i = 0; i < 8; i++) {
                    document.write("<tr><td style='width: 100px;'>Number " + i + " is:</td>");
                    myArray[i] = myArray[i].toFixed(3);
                    document.write("<td style='width: 100px; text-align: right;'>" + myArray[i] + "</td>");
                    document.write("<td style='width: 100px; text-align: right;'>" + myArray[i] + "</td></tr>");
                }

                 //-->
            </script>
        </table>
    </body>

</html>

如果我可以使用我实际的javascript文件创建test表并用我的测试数据填充,那么我应该能够自己计算其余部分(我想)。

以下是我目前能找到的几个最好的答案:

http://jsfiddle.net/drewnoakes/YAXDZ/

上面的链接来自stackoverflow,但我现在似乎找不到原始的帖子了。

http://www.java2s.com/Tutorial/JavaScript/0220__Array/OutputarrayelementinaHTMLtableformat.htm

任何帮助都是非常感谢的。由于我的经验有限,越简单越好。

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2013-04-21 07:42:23

问题是,如果您尝试使用JS编写<table><tr><td>标记,则每当您插入新标记时,浏览器都会尝试关闭它,因为它会认为代码中有错误。

不是逐行编写表,而是将表连接到一个变量中,并在创建后插入该变量:

代码语言:javascript
复制
<script language="javascript" type="text/javascript">
<!--

var myArray    = new Array();
    myArray[0] = 1;
    myArray[1] = 2.218;
    myArray[2] = 33;
    myArray[3] = 114.94;
    myArray[4] = 5;
    myArray[5] = 33;
    myArray[6] = 114.980;
    myArray[7] = 5;

    var myTable= "<table><tr><td style='width: 100px; color: red;'>Col Head 1</td>";
    myTable+= "<td style='width: 100px; color: red; text-align: right;'>Col Head 2</td>";
    myTable+="<td style='width: 100px; color: red; text-align: right;'>Col Head 3</td></tr>";

    myTable+="<tr><td style='width: 100px;                   '>---------------</td>";
    myTable+="<td     style='width: 100px; text-align: right;'>---------------</td>";
    myTable+="<td     style='width: 100px; text-align: right;'>---------------</td></tr>";

  for (var i=0; i<8; i++) {
    myTable+="<tr><td style='width: 100px;'>Number " + i + " is:</td>";
    myArray[i] = myArray[i].toFixed(3);
    myTable+="<td style='width: 100px; text-align: right;'>" + myArray[i] + "</td>";
    myTable+="<td style='width: 100px; text-align: right;'>" + myArray[i] + "</td></tr>";
  }  
   myTable+="</table>";

 document.write( myTable);

//-->
</script> 

如果您的代码位于外部JS文件中,请在HTML中创建一个元素,该元素的ID为您希望表出现的位置:

代码语言:javascript
复制
<div id="tablePrint"> </div>

在JS中,使用以下代码而不是document.write(myTable)

代码语言:javascript
复制
document.getElementById('tablePrint').innerHTML = myTable;
票数 22
EN

Stack Overflow用户

发布于 2013-05-22 16:00:44

这段漂亮的代码在这里创建了一个表,每个td都有数组值。这不是我的代码,但它对我有帮助!

代码语言:javascript
复制
var rows = 6, cols = 7;

for(var i = 0; i < rows; i++) {
  $('table').append('<tr></tr>');
  for(var j = 0; j < cols; j++) {
    $('table').find('tr').eq(i).append('<td></td>');
    $('table').find('tr').eq(i).find('td').eq(j).attr('data-row', i).attr('data-col', j);
  }
}
票数 0
EN

Stack Overflow用户

发布于 2015-10-16 17:32:17

代码语言:javascript
复制
In the html file there are three input boxes with userid,username,department respectively.

这些输入框用于从用户获取输入。

用户可以向页面添加任意数量的输入。

单击该按钮时,脚本将启用调试器模式。

在javascript中,要启用调试器模式,我们必须在javascript中添加以下标记。

/************************************************************************\

代码语言:javascript
复制
    Tools->Internet Options-->Advanced-->uncheck
    Disable script debugging(Internet Explorer)
    Disable script debugging(Other)

    <html xmlns="http://www.w3.org/1999/xhtml" >

    <head runat="server">

    <title>Dynamic Table</title>

    <script language="javascript" type="text/javascript">

    // <!CDATA[

    function CmdAdd_onclick() {

    var newTable,startTag,endTag;



    //Creating a new table

    startTag="<TABLE id='mainTable'><TBODY><TR><TD style=\"WIDTH: 120px\">User ID</TD>
    <TD style=\"WIDTH: 120px\">User Name</TD><TD style=\"WIDTH: 120px\">Department</TD></TR>"

    endTag="</TBODY></TABLE>"

    newTable=startTag;

    var trContents;

    //Get the row contents

    trContents=document.body.getElementsByTagName('TR');

    if(trContents.length>1)

    {

    for(i=1;i<trContents.length;i++)

    {

    if(trContents(i).innerHTML)

    {

    // Add previous rows

    newTable+="<TR>";

    newTable+=trContents(i).innerHTML;

    newTable+="</TR>";

    } 

    }

    }

    //Add the Latest row

    newTable+="<TR><TD style=\"WIDTH: 120px\" >" +
        document.getElementById('userid').value +"</TD>";

    newTable+="<TD style=\"WIDTH: 120px\" >" +
        document.getElementById('username').value +"</TD>";

    newTable+="<TD style=\"WIDTH: 120px\" >" +
        document.getElementById('department').value +"</TD><TR>";

    newTable+=endTag;

    //Update the Previous Table With New Table.

    document.getElementById('tableDiv').innerHTML=newTable;

    }

    // ]]>

    </script>

    </head>

    <body>

    <form id="form1" runat="server">

    <div>

    <br />

    <label>UserID</label> 

    <input id="userid" type="text" /><br />

    <label>UserName</label> 

    <input id="username" type="text" /><br />

    <label>Department</label> 

    <input id="department" type="text" />

    <center>

    <input id="CmdAdd" type="button" value="Add" onclick="return CmdAdd_onclick()" />
    </center>



    </div>

    <div id="tableDiv" style="text-align:center" >

    <table id="mainTable">

    <tr style="width:120px " >

    <td >User ID</td>

    <td>User Name</td>

    <td>Department</td>

    </tr>

    </table>

    </div>

    </form>

    </body>

    </html>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16126357

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档