PHP设置下拉框的选定值

时间:2009-07-26 23:44:09

标签: php html drop-down-menu

我有一个用PHP构建的下拉框。这是代码:

 $region_result = mysql_query("SELECT * FROM region ORDER BY region");    

 $dropdown = "<select name='region'>";
while($row = mysql_fetch_assoc($region_result)) {
    $rid = $row["id"];
    $region = $row["region"];

    $dropdown .= "\r\n<option value='{$row['rid']}'>{$region}</option>";
}
 $dropdown .= "\r\n</select>";

我需要在处理上述代码后设置下拉框的选定值。有没有简单的方法呢?

有没有人有任何建议?谢谢!

编辑:

谢谢大家的回答。让我解释一下我在做什么。我正在设置一个“编辑用户”页面,您可以在其中按多个条件搜索用户,然后结果以“编辑模式”列出 - 即 - 在文本框和下拉框中。因此,您可以编辑和更新用户。对于两个用户字段,我需要在下拉框中列出数据(以确保数据完整性和约束)。所以,我想显示那些可以更改的所有可能值的下拉框,除了我希望下拉列表的选定值是当前与用户关联的值。

所以,我能够使用deceze的建议 - 在我的while循环中设置我的PHP值与数据库结果,我插入了一个嵌套的while循环,它将构造$ dropdown,并在其中,嵌套的if循环。我并没有为所有这些嵌套循环而疯狂。以下是代码段:

 if (@mysql_num_rows($result)) {
        while ($r=@mysql_fetch_assoc($result)) {    
            $fname = $r["fname"];
            $lname = $r["lname"];
            $region = $r["region"];
            $role = $r["role"];
            $extension = $r["extension"];
            $username = $r["username"];
            $building = $r["building"];
            $room = $r["room"];?>

            <?php
            $dropdown = "<select name='region'>";
            while($row = mysql_fetch_assoc($region_result)) {
                $rid = $row["id"];
                $region2 = $row["region"];

                if($region == $region2){
                    $dropdown .= "\r\n<option selected='selected' value='{$row['rid']}'>{$region}</option>";
                }else{
                    $dropdown .= "\r\n<option value='{$row['rid']}'>{$region2}</option>";
                }
            }
            $dropdown .= "\r\n</select>";
            ?>

但是,我正在考虑将其更改为文本替换(由soulscratch和zombat建议),因为我认为它会更好地表现。

...当多个结果集符合搜索条件时,这似乎不起作用(因为第二个和第三个等结果的下拉框是空的)。

你们有什么想法?

4 个答案:

答案 0 :(得分:7)

通过构建字符串的方式,它是一个相当简单的str_replace(),这很好,因为它省去了需要正则表达式的麻烦:

$dropdown = str_replace("value='".$rid."'","value='".$rid."' selected=\"selected\"",$dropdown);

答案 1 :(得分:1)

如果您想在事后更改已组装的HTML ,则需要使用复杂的字符串替换方法或Javascript,这两者都不是一个好的选择。

您拥有的最佳选择是重新构建程序,以便在第一次循环时设置selected属性。

答案 2 :(得分:0)

您可以在$ _REQUEST ['region']

中找到它

答案 3 :(得分:0)

我敢打赌你会再遇到这个问题,这意味着要提出一个更灵活的解决方案是值得的。这是为此目的的想法:

首先,使用数组来保存下拉列表的选项。如果您需要具有相同选项的多个select元素,则可以免费重复使用该数组:

$options = array ();
while ($row = mysql_fetch_assoc($region_result)) {
  $options[$row['id']] = $row['region'];
}

然后,您可以将其提供给生成选择控件的函数:

function getSelect ($name, $options, $current)
{
  $markup = '<select name="' . htmlspecialchars($name) . '">';
  foreach ($options as $value => $label)
  {
    $selected = ($value == $current) ? ' selected="selected"' : '';
    $markup .= sprintf(
      "<option value=\"%s\"%s>%s</option>\r\n",
      htmlspecialchars($value), 
      $selected, 
      htmlspecialchars($label)
    );
  }
  $markup .= '</select>';
  return $markup;
}

(您还可以添加一个或多个可选参数来设置idclass等。

另外,你提到你因为速度而考虑切换方法,但这是时候担心性能的时间和地点。现在专注于可维护的代码,稍后变得必要的任何性能调整将更容易,更有效。