当我点击下拉列表中的item_id
列表之一时,我需要显示item_name
。当我点击提交时,item_name
和item_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>
答案 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看到它的工作原理。使用此方法,您无需在选项标记的值和文本与下划线之间进行组合。