nuc*_*age 2 html javascript json dynamic
我正在尝试使用Javascript中的表.
我有一个创建空表的功能,
//This function will create an empty table of a length of vars+1
//This function will create the header slots as well as empty data slots
function empty_Table(){
document.write("<table border=\"1\" id=\"myTable\" >");
var my_Structure = steps_Structure(steps);
var vars = my_Structure[0].second.split(",");//This will create an array,str, of multiple variables
//first row
document.write("<TR>");
for (var i = 0; i<vars.length+2; i+=2){
document.write("<TH></TH>");
}
document.write("</TR>");
//second row
document.write("<TR>");
for (var i = 0; i<vars.length+2; i+=2){
document.write("<TD></TD>");
}
document.write("</TR>");
//third row
document.write("<TR>");
for (var i = 0; i<vars.length+2; i+=2){
document.write("<TD></TD>");
}
document.write("</TR>");
document.write("</Table>");
return;
}
Run Code Online (Sandbox Code Playgroud)
以及修改该表的功能,
//This function is to begin drawing the variable display table
//This function should create a dynamic table that grows depending on the values in steps
function draw_Table(){
var my_Structure = steps_Structure(steps);
empty_Table();
var myTable = document.getElementById('myTable');
//draw first row
var vars = my_Structure[0].second.split(",");//This will create an array, of multiple variables
myTable.rows[0].cells[0].innerHTML = 'Variables:';
//for (var i = 0; i<vars.length; i+=2){
//document.write("<TH>",vars[i],"</TH>");
//}
//draw second row
var pairs = my_Structure[step_Cur].second.split(",");
myTable.rows[1].cells[0].innerHTML = 'Current Value:';
//for (var i = 1; i<(pairs.length); i+=2){
//document.write("<TD>",pairs[i],"</TD>");
//}
//third row
myTable.rows[2].cells[0].innerHTML = 'Last Value:';
}
Run Code Online (Sandbox Code Playgroud)
3条线给我带来了麻烦
myTable.rows[1].cells[0].innerHTML = 'Variables:';
myTable.rows[2].cells[0].innerHTML = 'Current Value:';
myTable.rows[3].cells[0].innerHTML = 'Last Value:';
Run Code Online (Sandbox Code Playgroud)
在chrome中,我看到错误"Uncaught TypeError:无法设置属性'innerHTML'未定义"但不知道如何修复它.
我不是一个javascript用户 - 我刚刚给了一个编写工具来显示解决一个函数的步骤 - 对此,我有很少的javascript知识,我正在努力与这个表
它应该如何工作:给定变量列表及其值,制作一个3行的表,列数对应于传递的变量数量.
Variables:| a | b | c
Current Val:| val1 | val2 | val3
previous val:| val1 | val2 | val3
Run Code Online (Sandbox Code Playgroud)
如果前一个val显示函数上一步的值,则当前值显示函数的每个变量的当前值,变量给出变量.
创建表时变量和标题是常量,每次按下"下一个"/"后退"按钮以显示下一个/上一个步骤时,表中的值将发生变化.
感谢您提供任何帮助!
编辑:在这个伟大的社区的帮助下找到了错误 - 未定义错误的"单元格"是由一个一个一个下标引起的,原始错误是由于创建我的表错误引起的.我<TR>在实际添加数据之前关闭了.
小智 6
我看到的一件事是你没有正确构建你的表:
//first row
document.write("<TR id=></TR>");
for (var i = 0; i<vars.length+2; i+=2){
document.write("<TH></TH>");
}
Run Code Online (Sandbox Code Playgroud)
在这里你创建一行,然后创建一个单元格.然后,当你得到表格行时,它是空的,这实际上是真的.
你需要的是这样的:
document.write("<TR>");
for (var i = 0; i<vars.length+2; i+=2){
document.write("<TH></TH>");
}
document.write("</TR>");
Run Code Online (Sandbox Code Playgroud)
这样表行就会有单元格.
如果这有助于您,请告诉我.