使用下拉选择菜单突出显示一行表格单元格

时间:2012-08-29 19:21:54

标签: javascript php html-table

我一直在努力寻找实现这一目标的解决方案。我有一个填充了数据库中数据的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,该行的所有单元格都会受到影响吗?

2 个答案:

答案 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";
    }
}