1

提交表单后,我在表单元素中保留值。我已经使用以下方法在选择框上正常工作:

<select name="BranchManager" class="formfield" id="BranchManager"onchange="document.forms[0].submit();SEinit();"><option value="">-- Select Manager --</option>
         <?php
            $area = $_POST['Area'];
            if ($area); {

               $BMquery = "SELECT DISTINCT Branch_Manager FROM Sales_Execs WHERE AREA = '$area' ".
               "ORDER BY Branch_Manager";

               $BMresult = mysql_query($BMquery);

               while($row = mysql_fetch_array($BMresult))
               {
                  echo "<option value=\"".$row['Branch_Manager']."\">".$row['Branch_Manager']."</option>\n  ";
               }
            }

        $branchmanager = $POST['BranchManager'];
        ?>

       <script type="text/javascript">
document.getElementById('BranchManager').value = <?php echo json_encode(trim($_POST['BranchManager']));?>;
</script>

哪个很好用(抱歉,如果它不是最干净/最有效的代码,我会尽力而为!)下一个字段是一个文本字段,需要根据上面的分公司经理名称进行填充。所以我用过:

<input name="BranchNum" type="text" class="formfield" id="BranchNum" size="3" maxlength="3" />
                      <?php

                $bm = $_POST['BranchManager'];

                if ($bm); {

                $BNumquery = "SELECT DISTINCT BRANCH_NUM FROM Sales_Execs WHERE Branch_Manager = '$bm' ";

                $BNumresult = mysql_query($BNumquery);

                }

            $branchnum = $POST['BranchNum'];
            ?>

   <script type="text/javascript">
document.getElementById('BranchNum').value = <?php echo json_encode($BNumresult);?>;
</script>

哪个不起作用...我在哪里出错了?

4

4 回答 4

0

您需要 mydql_fetch 函数从 $result 检索数据。

if($row = mysql_fetch_array($BNumresult))
    $branchNum = $row[BRANCH_NUM];

当您的输入标签大小为 3 时,为什么要使用 json_encode?

于 2012-08-02T21:51:37.420 回答
0

为什么在 if 条件检查之后有分号?

if ($bm);

if ($area);

这将始终终止语句,并且无论 $bm 或 $area 中的值如何,花括号中的任何内容都将始终执行

于 2012-08-02T16:59:38.903 回答
-1

您需要将 value="<? echo $variableName; ?>" 放入输入字段中

于 2012-08-02T16:46:34.483 回答
-1

原因是因为a)你没有选择echo,b)你必须echo在不同的地方而不是在选择中。您必须在value输入的部分中回显。

<?php
    $bm = mysql_real_escape_string($_POST['BranchManager']);
    if ($bm) {
        $BNumquery = "SELECT DISTINCT BRANCH_NUM FROM Sales_Execs WHERE Branch_Manager = '$bm' ";
        $BNumresult = mysql_query($BNumquery);
    }
    $branchnum = $POST['BranchNum'];
?>
<input name="BranchNum" 
    type="text" 
    class="formfield" 
    id="BranchNum" 
    size="3" 
    maxlength="3" 
    value="<?php echo htmlspecialchars($branchnum); ?>" />

根据评论,它们是正确的;你不应该使用mysql_*. 相反,看看PDO;尽管这超出了您的问题范围。

于 2012-08-02T16:47:55.103 回答