嗨,我有两个下拉框,用于从 mysql 表中过滤数据,问题是当我使用 isset 确定它们中的任何一个是否选择了任何值时,这些框总是显示为已设置。
这是投递箱的代码。
<?php
if (isset($_POST['referrer']) && $_POST['referrer'] != "referrer") {
$select = $_POST['referrer'];
}
?>
<select name="referrer">
<option value="">Referrer</option>
<?php
// Get records from database (table "name_list").
$list=mysql_query("select DISTINCT referrer from masterip_details WHERE country_code='GB' AND TRIM(IFNULL(referrer,'')) <> '' order by referrer DESC");
// Show records by while loop.
while($row_list=mysql_fetch_assoc($list)){
$referrer = $_POST['referrer']; ?>
<option value="<?php echo $row_list['referrer']; ?>" <?php if($row_list['referrer']==$select){ echo "selected"; } ?>><?php echo $row_list['referrer']; ?></option>
<?php
}
?>
</select>
<?php
if (isset($_POST['returning']) && $_POST['returning'] != "returning") {
$select2 = $_POST['returning'];
}
?>
<select name="returning">
<option value="">Referrer</option>
<?php
// Get records from database (table "name_list").
$list2=mysql_query("select * from repeater_drop_down order by id DESC");
// Show records by while loop.
while($row_list2=mysql_fetch_assoc($list2)){
$returning = $_POST['returning']; ?>
<option value="<?php echo $row_list2['value']; ?>" <?php if($row_list2['value']==$select2){ echo "selected"; } ?>><?php echo $row_list2['title']; ?></option>
<?php
}
?>
</select>
现在这里是代码的 isset 元素。
$returning = $_POST['returning'];
$referrer = $_POST['referrer'];
if (isset($returning, $referrer)){
//code //
elseif (isset($returning)){
///code //
elseif (isset($referrer)){
//code //
else {
//code
}
我没有包括查询,因为它们工作正常,但无论我是否选择两个下拉框,代码都会自动转到两个变量的第一个 isset,即使只有一个框选择了选项。
任何意见或建议将不胜感激。