0

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> 
4

2 回答 2

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/

希望这可以帮助!

于 2012-12-09T09:01:56.943 回答
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看到它是如何工作的。使用这种方法,您不需要将选项标签的值和文本与下划线结合起来。

于 2012-12-09T09:19:55.167 回答