3

我有一个小问题。我有一个edit.php 页面。此页面列出了可以编辑的产品信息。

我运行一个查询

while($rows=mysql_fetch_assoc($query)){


echo"<form method=\"POST\" action=\"edit.php\">";
echo "<input type ='hidden' name='ID' value = '{$rows['ID']}'>"; 
echo "Product:&nbsp <input type='text' name='product' value = '{$rows['ProductName']}'>"; 

在 while 循环之前,我将详细信息存储在变量中,如下所示:

$hiddenid = $_POST['ID'];   
$productName = $_POST['product'];

这有效。当我加载 php 表单时,它会显示从数据库中检索到的产品名称(在文本字段中)。但是问题是我想将产品名称存储为用户已经选择的下拉列表框,然后选择它。

因此,基本上我希望做的不是在文本框中显示数据库检索到的选项,而是希望用户选择的选项显示在下拉列表框中。

我希望这是有道理的?为什么我的选项值根本没有显示,其次它们也没有显示 SELECTED 选项(从数据库中检索)。

请问有什么帮助吗?

4

2 回答 2

5

专注于这一领域,你应该得到一个 PHP 错误,除非它是一个复制错误。请注意以下更改:

while($rows=mysql_fetch_assoc($query)){
?>
    <form method=\"POST\" action=\"edit.php\">
    <input type ='hidden' name='ID' value = '<?php echo $rows['ID'];?>'>
    <select name ="pnames">
        <?php foreach ($arrayproducts as $key => $value) {
        ?>  
            <option value = "<?php echo $key; ?>" 
            <?php
                if ($key == $productName){
                    echo 'selected="selected"';
                } 
            ?> >
            <?php echo $value; ?> 
            </option>
     <?php } //end foreach ?>   
   </select>
<?php }//end while ?>

一开始的 PHP 段中有纯 HTML 代码。

另外,我相信你想要

if ($value == $productName){
于 2013-03-13T19:25:45.290 回答
1

这可能不是一个很好的地方,但是因为我每天都会看到大量可怕的代码,所以我想我会插话的。

首先,检查您的输入。您永远不应该相信来自用户 $_GET、$_POST 等的任何变量。原始代码的松散只是在寻找 SQL 注入攻击。

<?php

这件事看起来像是在期待某种传递的 ID,然后会从数据库中提取 productName ......这真的不清楚。所以我们假设已经定义了变量。需要使用这样的代码:

if(!empty($_GET['id'])&&is_numeric($_GET['id'])){
   $id=$_GET['id'];
} else {
   $id='';
}

//Declare your array
$arrayproducts = array();


while($rows=mysql_fetch_array($query)){

你需要在这里为返回的数组调用一些东西......没有看到 SQL 很难说出你的期望,但你的标注应该看起来像这样......

//Whatever the name from SQL is for the column
$temp_ID = $rows['id'];

//Whatever the name for the product column is
$temp_Prod = $rows['prod'];

//Load the array
$arrayproducts[$temp_ID]=$temp_Prod;
}

最好为所有内容加载一个 var,然后一次性发布,而不是进出 PHP。代码将更快,您将能够跟踪代码。

$page = "<form method=\"POST\" action=\"edit.php\">";

检查该 ID 是否有效。正则表达式是最好的,但这里一次只做一件事。

if(!empty($id)){
    $page .= "<input type =\"hidden\" name=\"ID\" value = \"$id\">";
} 
$page .= "<select name =\"pnames\">\n";

foreach ($arrayproducts as $key => $value) {

   $page .= "<option value = \"$key\"";

最好使用 mysql 的自动增量字段和内置 ID,这样就不会有重复 ID 接管现有记录的机会。

      if ($id == $key){
        $page .= ' selected="selected"';
      }
   $page .= ">$value</option>\n";

//close the foreach
}

$page .= "</select>\n"; 

print $page;
?>
于 2013-03-13T17:29:32.467 回答