PHP - MySQL:当我在选项下拉列表中选择item_name时,如何在同一页面中获取item_id

时间:2012-12-09 08:49:55

标签: php mysql

当我点击下拉列表中的item_id列表之一时,我需要显示item_name。当我点击提交时,item_nameitem_id$_POST获得。 javascript可以用来做吗?

<?php
    $brg="SELECT item_id, item_name FROM tblItem";
    $b=mysql_query($brg);
?>
<td align="center">
    <select name="item_name">
        <?php while($br=mysql_fetch_array($b)){ ?>
        <option value=<?echo $br[0].'_'.$br[1]?> selected>
            <?php echo $br[1]; ?>
        </option>
        <?php } ?>        
    </select>
</td> 

2 个答案:

答案 0 :(得分:0)

Jup,这可以使用Javascript。

您的HTML:

<select name="item_name">
    <option value="1_Cheese">Cheese</option>
    <option value="2_Cars">Cars</option>
    <option value="3_Planes">Planes</option>
</select>

<input type="button" onclick="alert(getSelectedValue())" value="Get Select Id" />​

和您的Javascript,从选项值访问ID:

function getSelectedValue()
{
    var sel = document.getElementsByName('item_name')[0];
    return sel.options[sel.selectedIndex].value.split("_")[0];
}

看到这个小提琴:http://jsfiddle.net/acz6Q/

使用jQuery(也附加了一个事件处理程序)会更容易一些:

$(document).ready(function()
{
    $("select[name=item_name]").on("change", function()
    {
         alert("new item id = " + $(this).val().split("_")[0]);
    });    ​
});

这是jQuery版本的小提琴:http://jsfiddle.net/acz6Q/1/

希望这有帮助!

答案 1 :(得分:0)

试试这个:

<form action="" method="post">
    <input type="hidden" id="item_id" name="item_id" />
    <input type="hidden" id="item_name" name="item_name" />
    <select id="my_select" name="my_select">
        <option value="item_id_1">item_name_1</option>
        <option value="item_id_2">item_name_2</option>
        <option value="item_id_3">item_name_3</option>
    </select>
</form>

<script type="text/javascript">
    $(document).ready(function() {
        $("#my_select").change(function() {
            $("#item_id").val($("#my_select").val());
            $("#item_name").val($("#my_select option:selected").text());
        });
    });
</script>  

请注意,您需要首先包含jQuery库。你也可以从jsfiddle.net/2FsNP/3看到它的工作原理。使用此方法,您无需在选项标记的值和文本与下划线之间进行组合。