我有一个带有选择下拉列表的 HTML 表单。我想从我的 MySQL 数据库中填充下拉列表。HTML 表单已经有一些 java 脚本来处理日期选择器,以及表单中某个字段的当前日期。
我可以手动对表单进行编码以供选择,但希望它来自 MySQL。我正在使用的 php 我放入了它自己的文件 name.php 以确保它正常工作。我在 php 中添加了一些 echo 语句来构建表单和选择,然后填充选择并关闭它。这作为一个独立的 php 工作得很好。
当我在选择定义下的表单中附加 php 时,它根本不会填充选择,它是空白/空的。如果我以选择选项的格式添加一些回显语句以输出信息,则第一个回显永远不会显示,并且随后的回显会显示,但任何变量都会显示为变量名称。
<form id="form1" name="form1" method="post" action="/db_log.php">
Field:<select name="id">
<?php
require_once dirname(__FILE__) . '/db_connect.php';
$db = new DB_CONNECT();
$query="SELECT id, name FROM file order by name";
$result=mysql_query($query);
while ($row = mysql_fetch_array($result)) {
$id = $row['id'];
$name =$row['name'];
echo "<option value=\"$id\"> $name </option>";
}
?>
</select><br />
</form>
以上是一个空的选择下拉菜单。但这作为 PHP 文件非常有用。
<?php
echo "<form id=\"form1\" name=\"form1\" method=\"post\" action=\"/db_log.php\">";
echo "Select:<select name=\"id\">";
require_once dirname(__FILE__) . '/db_connect.php';
$db = new DB_CONNECT();
$result=mysql_query("SELECT id, name FROM file order by name");
while ($row = mysql_fetch_array($result)) {
$id = $row['id'];
$name =$row['name'];
echo "<option value=\"$id\"> $name </option>";
}
echo "</select><br />";
echo "</form>";
?>
如果我在 HTML 表单中添加一个回声,例如在任何其他回声之前添加一个测试回声,它将被忽略。
<form id="form1" name="form1" method="post" action="/db_log.php">
Field:<select name="id">
<?php
echo "<option value=\"1\"> Test-name </option>";
require_once dirname(__FILE__) . '/db_connect.php';
$db = new DB_CONNECT();
$query="SELECT id, name FROM file order by name";
$result=mysql_query($query);
while ($row = mysql_fetch_array($result)) {
$id = $row['id'];
$name =$row['name'];
echo "<option value=\"$id\"> $name </option>";
}
?>
</select><br />
</form>
唯一显示的是选择 $name 的选项