For 循环 if 语句在 Javascript 中识别 == 但不识别 <
For loop if statement recognizes == but not < in Javascript
我正在尝试创建一个脚本,将我的 table 中的某些值替换为其他值。我在 HTML 中生成了一个工作正常的 table。我想用值 1/8" 替换前 3 行中第 4 列中的元素。
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 3) {
cells[3].innerHTML = '1/8"';
}
}
使用上面的代码对我的 table 没有任何作用,但是使用下面的代码将第 4 个元素替换为我的值
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i == 3) {
cells[3].innerHTML = '1/8"';
}
}
为什么 == 有效,而 < 无效?是否有简单的方法来打印出 for 循环的输出,以便我可以更轻松地进行调试 - 我是编码新手。谢谢!
编辑:这是我正在使用的 HTML 以及 CSS(可能没有必要)
HTML5:
<div class="eo_product_listing_table">
<table class="tableizer-table">
<thead>
<tr class="tableizer-firstrow">
<th>Item #</th>
<th>Type</th>
<th>Operting Temp.</th>
<th>O.D.</th>
<th>Length</th>
<th>Material</th>
<th>Junction</th>
<th>Price</th>
<th>Order</th>
</tr>
</thead>
<tbody>
<!--1/8-->
<!--6-->
<tr>
<td>NB4-CAXL-14U-12-AAG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-AAU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-AAE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<!--12-->
<tr>
<td>NB4-CAXL-14U-12-ABG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ABU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ABE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<!--18-->
<tr>
<td>NB4-CAXL-14U-12-ACG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ACU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ACE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
</tbody>
CSS3
.eo_product_listing_table {}
.tableizer-table tr:nth-child(even) {
background-color: #eee;
}
table.tableizer-table {
font-size: 12px;
border: 1px solid #CCC;
font-family: Arial, Helvetica, sans-serif;
color: black;
}
.tableizer-table td {
padding: 4px;
margin: 3px;
border: 0px solid #CCC;
text-align: left;
color: black;
}
.tableizer-table th {
background-color: #104E8B;
color: #FFF;
font-weight: bold;
text-align: left;
}
.tableizer-firstrow {
background-color: #000;
color: whtie;
}
对于循环的前三个迭代 (i < 3
),您只是一次又一次地将同一单元格的 innerHTML
设置为 '1/8"'
。
也许你打算这样做:
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 3) {
cells[i].innerHTML = '1/8"';
}
}
您将脚本用于所有 <tr>
标签,就像@Luaan 所说的那样 - 查看您的 HTML 文件。也就是说,你必须计算表格 1,而不是表格 0。然后一切正常。
var rows = document.getElementsByTagName('tr');
for (var i = 1; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 4) {
cells[3].innerHTML = '1/8"';
}
}
好的,现在您已经发布了 HTML,错误显而易见 :) 您发现的第一个 tr
不包含任何 td
,所以您得到未处理的错误和函数中断。
您只需查找 tbody
中的行,排除 theader
或 tfooter
中的任何行。仅遍历特定 table 的行而不是整个文档中的所有行通常也是一个好主意。您甚至可以给特定的 tbody
一个 ID 并直接访问它,从而避免所有这些问题。
我正在尝试创建一个脚本,将我的 table 中的某些值替换为其他值。我在 HTML 中生成了一个工作正常的 table。我想用值 1/8" 替换前 3 行中第 4 列中的元素。
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 3) {
cells[3].innerHTML = '1/8"';
}
}
使用上面的代码对我的 table 没有任何作用,但是使用下面的代码将第 4 个元素替换为我的值
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i == 3) {
cells[3].innerHTML = '1/8"';
}
}
为什么 == 有效,而 < 无效?是否有简单的方法来打印出 for 循环的输出,以便我可以更轻松地进行调试 - 我是编码新手。谢谢!
编辑:这是我正在使用的 HTML 以及 CSS(可能没有必要)
HTML5:
<div class="eo_product_listing_table">
<table class="tableizer-table">
<thead>
<tr class="tableizer-firstrow">
<th>Item #</th>
<th>Type</th>
<th>Operting Temp.</th>
<th>O.D.</th>
<th>Length</th>
<th>Material</th>
<th>Junction</th>
<th>Price</th>
<th>Order</th>
</tr>
</thead>
<tbody>
<!--1/8-->
<!--6-->
<tr>
<td>NB4-CAXL-14U-12-AAG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-AAU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-AAE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>6"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<!--12-->
<tr>
<td>NB4-CAXL-14U-12-ABG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ABU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ABE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>3/8"</td>
<td>12"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<!--18-->
<tr>
<td>NB4-CAXL-14U-12-ACG</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Grounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ACU</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Ungrounded</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
<tr>
<td>NB4-CAXL-14U-12-ACE</td>
<td>K</td>
<td>-270°C to 1372°C</br>–454°F to 2501°F</td>
<td>1/8"</td>
<td>18"</td>
<td>316SS</td>
<td>Exposed</td>
<td>.00</td>
<td><a href="/">Order</a></td>
</tr>
</tbody>
CSS3
.eo_product_listing_table {}
.tableizer-table tr:nth-child(even) {
background-color: #eee;
}
table.tableizer-table {
font-size: 12px;
border: 1px solid #CCC;
font-family: Arial, Helvetica, sans-serif;
color: black;
}
.tableizer-table td {
padding: 4px;
margin: 3px;
border: 0px solid #CCC;
text-align: left;
color: black;
}
.tableizer-table th {
background-color: #104E8B;
color: #FFF;
font-weight: bold;
text-align: left;
}
.tableizer-firstrow {
background-color: #000;
color: whtie;
}
对于循环的前三个迭代 (i < 3
),您只是一次又一次地将同一单元格的 innerHTML
设置为 '1/8"'
。
也许你打算这样做:
var rows = document.getElementsByTagName('tr');
for (var i = 0; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 3) {
cells[i].innerHTML = '1/8"';
}
}
您将脚本用于所有 <tr>
标签,就像@Luaan 所说的那样 - 查看您的 HTML 文件。也就是说,你必须计算表格 1,而不是表格 0。然后一切正常。
var rows = document.getElementsByTagName('tr');
for (var i = 1; i < rows.length; i++) {
var cells = rows[i].getElementsByTagName('td');
if (i < 4) {
cells[3].innerHTML = '1/8"';
}
}
好的,现在您已经发布了 HTML,错误显而易见 :) 您发现的第一个 tr
不包含任何 td
,所以您得到未处理的错误和函数中断。
您只需查找 tbody
中的行,排除 theader
或 tfooter
中的任何行。仅遍历特定 table 的行而不是整个文档中的所有行通常也是一个好主意。您甚至可以给特定的 tbody
一个 ID 并直接访问它,从而避免所有这些问题。