从下拉选项(int)类型中获取值


PHP Get value from drop down option (int) type

我从下拉列表中捕获值有问题。这是我的下拉列表代码,它是产品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,对吗?这是数据类型的不匹配。