如何显示已在PHP中选择了哪些表单元素

时间:2009-07-01 14:47:47

标签: php html html-form html-select

如何让此代码显示已选择哪个选项?

这基本上是一个编辑页面,它从数据库中提取信息并填充相关字段

我在页面上有一个下拉菜单,多个选择框和单选按钮以及一些元素。信息在元素中显示得很好,但如果它们与数据库中的信息匹配,我无法弄清楚如何显示所选的s和单选按钮。

代码:

<select name="client">


    <option value="empty">Change Client...</option>
 <?php
                $result2 = mysql_query("SELECT name FROM clients") or die("Database query failed: " . mysql_error());    

while($row = mysql_fetch_assoc($result2)) {
    $clientlist = $row['name'];
    $clientname = htmlspecialchars($row['name']);

    if ($_POST['client'] == $clientlist)
    { 

    echo '<option value="' . $clientlist . '" selected="selected" >' . $clientname . '</option>' . '\n';
    }
    else{
    echo '<option value="' . $clientlist . '" >' . $clientname . '</option>' . '\n';
}
}


?>
</select>

    </p>
<p class="subheadsmall">Core Classification</p>

<?php

switch ($niche) {
    case "brand":
        echo '<input type="radio" name="niche" value="Brand" checked="checked" />Brand';
        echo '<input type="radio" name="niche" value="Marketing" />Marketing';
        echo '<input type="radio" name="niche" value="Communication" />Communication';
        break;
    case "marketing":
        echo '<input type="radio" name="niche" value="Brand" />Brand';
        echo '<input type="radio" name="niche" value="Marketing" checked="checked" />Marketing';
        echo '<input type="radio" name="niche" value="Communication" />Communication';
        break;
    case "communication":
        echo '<input type="radio" name="niche" value="Brand" />Brand';
        echo '<input type="radio" name="niche" value="Marketing" />Marketing';
        echo '<input type="radio" name="niche" value="Communication" checked="checked" />Communication';
        break;
    default;
        echo '<input type="radio" name="niche" value="Brand" />Brand';
        echo '<input type="radio" name="niche" value="Marketing" />Marketing';
        echo '<input type="radio" name="niche" value="Communication" />Communication';
    break;
}

?>

<p class="subheadsmall">Strategies</p>

<p class="sidebargrey">

<?php

            $result = mysql_query("SELECT strategies FROM studies WHERE id = '$id';
                if (!$result) {
                    die("Database query failed: " . mysql_error());
                }

while($row = mysql_fetch_array($result)) {
    $strategyname = $row['strategies'];


    echo $strategyname.'<br />';
}

?>
        <p class="subheadsmall">Add a strategy... (hold down command key to select more than one)</p>

<select name="strategies[]" multiple="multiple">
     <?php

            $result = mysql_query("SELECT * FROM strategies");
                if (!$result) {
                    die("Database query failed: " . mysql_error());
                }

while($row = mysql_fetch_array($result)) {
    $strategylist = $row['name'];
    $strategyname = htmlspecialchars($row['name']);
$pagelink = str_replace(" ","_",$strategylist);

    echo '<option value="<a href=&quot;strategies.php?strategy=' . $pagelink . '&quot;>'.$strategyname.'</a>" >' . $strategyname . '</option>' . '\n';
}

?>
    </p>

3 个答案:

答案 0 :(得分:0)

OPTION HTML Spec

将selected =“selected”更改为刚刚选中。看起来该属性不需要分配。

您可能还想检查正在输出的HTML,以确保您的作业评估为true。

答案 1 :(得分:0)

您可以使用javascript来执行此操作。我的例子使用了jquery

首先给每个复选框一个id

echo '<input type="radio" name="niche" id="brand" value="Brand" />Brand';
echo '<input type="radio" name="niche" id="marketing" value="Marketing" />Marketing';
echo '<input type="radio" name="niche" id="communication" value="Communication" />Communication';

那你的JS就是

$( "brand" ).attr( "checked", true ); // this would check the brand box

所以你可以根据需要写出来。

答案 2 :(得分:0)

您应该 - 如果可能 - 将该组无线电打印更改为for循环。然后你可以做这样的事情:

foreach ($possibleRadios as $key => $val)
{ 
    echo '<input type="radio" name="' . $val->name . '" value="' . $val->id . '" ' .  ($isSelected($val->id) ? 'selected="selected' : '') . ' />$val->prettyName';
}