我有一个简单的php表单,它允许用户从主题区域的下拉列表中选择返回一组数据库(例如http://library.wabash.edu/biology.php)。如您所见,在进行选择并单击“提交”之前,不会返回任何内容。是否有可能在加载页面时加载一组数据库(生物学数据库将载入生物部门页面等),但是还允许用户再次选择,如我现在所做的那样?我的经验不足,提前表示道歉。在页面加载时加载php表单搜索结果
<form action="<?php echo htmlentities($_SERVER['PHP_SELF']); ?>" method="post">
<select name="choice" id="choice">
<option value="Biology">Biology</option>
<option value="Chemistry">Chemistry</option>
<option value="Computer Science">Computer Science</option>
<option value="Mathematics">Mathematics</option>
<option value="Medicine">Medicine</option>
<option value="Physics">Physics</option>
</select>
<input type="submit" name="submit" value="Go" style="margin-left: 10px">
<input type="submit" name="reset" value="Clear" style="margin-left: 10px">
<input type="hidden" name="submitted" value="true"/>
</form>
<?php
if(isset($_POST['submit'])) {
$choice=$_POST['choice'];
$localhost="localhost";
$username="xxxxxxx";
$password="xxxxxxx";
$database="xxxxxxx";
$linkid=mysql_connect($localhost,$username,$password);
@mysql_select_db($database) or die("Unable to select database");
mysql_select_db("databases",$linkid);
$resultid=mysql_query("SELECT name, mobile, app, tutorial, help
FROM databaselist
WHERE dept
LIKE '%{$choice}%'
ORDER BY sortname ASC", $linkid);
echo"<table>";
while ($row = mysql_fetch_row($resultid))
{
echo"<tr>";
foreach ($row as $field)
{
echo"<td>$field</td>";
}
echo"</tr>";
}
echo"</table>";
mysql_close($linkid);
}
?>
我已经尝试了几天 - 我可以做的GET为了建立链接时,用户做出选择,没有问题,但我不知道如何使一组数据库在页面加载时出现而不是所有的数据库。使用表单中的选定属性可以让用户轻松点击Go来获取该部门的数据库,但直到单击Go时,整个列表才会显示在页面上。抱歉! – user1766841
您是否删除了“提交”验证? “if(isset($ _ POST ['submit']))”这是停止查询在请求上执行的唯一点。如果你删除它,并有链接,如mypage.com/index.php?choice=Biology,生物学集将只出现。 –