0

我有以下代码来创建一个下拉列表:

<body>
    <form method="post">
        <table>
            <tr>
                <td>Firm Name:</td>
                <td><input type="text"class="input_text_long"  name="name" value="<?php echo $name ?>"/></td>
            </tr> 
            <tr>
                <td>Hub Name:</td>
                <select>
                    <option value="">---Select---</option>
                    <?php
                        $list=mysql_query("SELECT * FROM hub");
                        while($row = mysql_fetch_assoc($list)) {
                    ?>
                    <option value=<?php echo $row_list['name'];?>
                    </option>
                    <?php } ?>
                </select>
            </tr> 
                <td>&nbsp;</td>
                <td><input type="submit" name="save" value="Save" /></td>
            </tr>
        </table>
    </form>
</body> 

但是,这不会显示任何下拉列表。它只显示一个文本框。谁能告诉我我做错了什么,好吗?或者如何在表单中创建下拉框。

4

3 回答 3

0

我认为问题在于这一行:

<?php echo $row_list['name'];?>

它应该是:

<?php echo $row['name'];?>

此外,您的开始<option>标签没有结束>

<option value=<?php echo $row['name'];?>></option>
于 2013-08-12T12:58:10.383 回答
0

你的option标签是错误的。

正确的语法<option value="VALUE">OPTION NAME</option>

<select>
    <option value="">---Select---</option>
    <?php
    $list = mysql_query("SELECT * FROM hub");
    while ($row = mysql_fetch_assoc($list)) {
          $name = $row['name'];
    ?>
        <option value="<?php echo $name; ?>"><?php echo $name; ?></option>
    <?php
    }
    ?>
</select>
于 2013-08-12T12:58:32.180 回答
0

更改此行

<option value=<?php echo $row_list['name'];?></option>

<option value="<?php echo $row['name'];?>"><?php echo $row['name'];?></option>
于 2013-08-12T13:01:07.063 回答