我有一个用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建议),因为我认为它会更好地表现。
...当多个结果集符合搜索条件时,这似乎不起作用(因为第二个和第三个等结果的下拉框是空的)。
你们有什么想法?
答案 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;
}
(您还可以添加一个或多个可选参数来设置id
,class
等。
另外,你提到你因为速度而考虑切换方法,但这是时候担心性能的时间和地点。现在专注于可维护的代码,稍后变得必要的任何性能调整将更容易,更有效。