我一直在努力寻找实现这一目标的解决方案。我有一个填充了数据库中数据的HTML表单。该表由6列组成,一列名为“Status”,下面的每个单元格都有一个下拉菜单。菜单包含三个值'待定''已批准'和'已批准',当用户从下拉列表中选择一个值时,该行上的所有单元格都应更改颜色(绿色 - 已批准,琥珀色 - 待定,红色 - 已批准)
到目前为止,这是我的代码:
<?php
$result = mysql_query("SELECT * FROM Orders")
or die (mysql_error());
?>
<table class="table1" style="background-color:#ffffff;" >
<h4>Purchase Orders</h4>
<tr>
<th>Order Number</th>
<th>Order Date</th>
<th>Ordered By</th>
<th>Supplier</th>
<th>Total Price</th>
<th>Status</th>
</tr>
<?php
while($row=mysql_fetch_array($result)){
echo "</td><td>";
echo $row['Orderno'];
echo "</td><td>";
echo $row['Orderdate'];
echo "</td><td>";
echo $row['Orderedby'];
echo "</td><td>";
echo $row['Supplier'];
echo "</td><td>£";
echo $row['totalprice'];
echo "</td><td>";
echo ' <select id="'.$row['Orderno'].'" onchange="myJSFunction(this)">
<option></option>
<option>Approved</option>
<option>Pending</option>
<option>Disapproved</option>
</select>';
echo "</td></tr>";
}
echo "</table>";
?>
如果有人能指出我正确的方向,我将不胜感激。如何为每个颜色更改创建三个函数,然后将它们应用于每个选项值。如果我申请Orderno,该行的所有单元格都会受到影响吗?
答案 0 :(得分:1)
我知道你没有使用jQuery标记你的问题,但是如果它是一个选项,你可以使用它:
$(document).ready(function() {
var color = ['none', 'green', 'yellow', 'red'];
$('table.table1').on('change','select', function() {
$(this).parents('tr').css('background', color[$(':selected', this).index()]);
});
});
<强> jsFiddle example 强>
答案 1 :(得分:0)
试试这个(jsFiddle):
function myJSFunction(element)
{
var row = element.parentNode.parentNode;
switch(element.options[element.selectedIndex].innerHTML)
{
case "Pending":
row.style.background = "#FF7E00";
break;
case "Approved":
row.style.background = "green";
break;
case "Disapproved":
row.style.background = "red";
break;
default:
row.style.background = "white";
}
}