我从下拉列表中捕获值有问题。这是我的下拉列表代码,它是产品id。
<select name="id" id="id" ONCHANGE="location =this.options[this.selectedIndex].value;" >
<option value="---">---</option>
<?php
foreach( $products as $ID => $info ){
echo '<option value="new_purchase.php?id=' . $ID . '"';
echo isset( $id ) && $id == $ID ? ' selected="selected"' : '';
echo '>' . $info['id'] . '</option>'; }
?>
</select>
这是我捕获值的代码。
$id = $mysqli->real_escape_string ($_POST['$("#id:selected").val()'] );
查询运行,但无论我选择什么,它都将0存储为产品id值。
你正在混搭PHP和JavaScript。您只需要$_POST
数组中表单字段的名称:
$id = $mysqli->real_escape_string($_POST['$("#id:selected").val()']);
应:$id = $mysqli->real_escape_string($_POST['id']);
和改变
echo '<option value="new_purchase.php?id=' . $ID . '"';
echo '<option value="' . $ID . '"';
UPDATE Part Deaux
和改变
ONCHANGE="location =this.options[this.selectedIndex].value;"
ONCHANGE="location = 'new_purchase.php?id=' + this.options[this.selectedIndex].value;"
由于您没有提交表单,只是更改window.location
,您的POST数组将为空。相反,您应该读取GET参数,而不是POST:
$id = $mysqli->real_escape_string($_GET['id']);
try this:
<select name="id" id="id" ONCHANGE="location ='http://site.com/new_purchase.php?id='+this.options[this.selectedIndex].value;" >
<option value="---">---</option>
<?php
foreach( $products as $ID => $info ){
echo '<option value="'.$ID .'"';
echo isset( $id ) && $id == $ID ? ' selected="selected"' : '';
echo '>' . $info['id'] . '</option>'; }
?>
</select>
我猜你的数据库是期待整数列的产品id,对吗?这是数据类型的不匹配。