我正在开发一个网站,这是我的代码,在我的代码中,我有两个id sId
(section)和ssId
(SubSectionId),我有一个页面,比如说index.php
,现在我正在制作这样的url——当我点击左边的导航栏时,我有链接,当我点击一个链接时,它会发送一个类似localhost/index.php?sId=29&ssId=0
的id
现在,我想通过录制发送id localhost/index.php?sId=29&ssId=181
的子部分的相同左导航,使用id在相同的页面index.php
上显示ssId=181
数据
这里的问题是,结果显示在sId=29
的内容区上,而不是ssId=181
,并且两者都存储在数据库中。。
if(isset($_GET['sId']) && !empty($_GET['sId']))
{
?>
<div>
<br /><br />
<h2 class="heading">
<?php
$sId = intval($_GET['sId']);
$qry = "SELECT `SectionId`,`Title`,`Details` FROM `section` WHERE `SectionId` = $sId";
$records = mysql_query($qry);
while($record= mysql_fetch_array($records))
{
echo $record['Title'];
?>
</h2>
<br />
<p>
<?php
echo $record['Details'];
}
?>
</p>
</div>
</div>
<?php
}
elseif(isset($_GET['sId']) && !empty($_GET['sId']) && isset($_GET['ssId']) && !empty($_GET['ssId']))
{
?>
<div>
<br /><br />
<h2 class="heading">
<?php
$sId = intval($_GET['sId']);
$ssId = intval($_GET['ssId']);
$qry = "SELECT SubSectionId,Title,Details FROM `pages` WHERE `SubSectionId` = $ssId";
$records = mysql_query($qry);
while($record= mysql_fetch_array($records))
{
echo $record['Title'];
?>
</h2>
<br />
<p>
<?php
echo $record['Details'];
}
?>
</p>
</div>
</div>
<?php
}
}
希望你们能理解。提前谢谢。
如果我理解正确,你说的是以下内容。
- 脚本需要一个sid和/或ssid作为输入
- 如果提供了任何一个,脚本将从DB加载相关内容并显示它
- 但是,当前您的脚本不显示ssid的内容,只显示sid的内容
我说得对吗?
尝试使用两个IF块而不是一个IF/ELSE。这将确保所有满足的条件都将运行,而不仅仅是一个条件。
此外,您可以坚持只使用empty
函数调用。
if ( !empty($_GET['sId']) ) {
//load and show content for section
}
if ( !empty($_GET['ssId']) ) {
//load and show content for sub section
}
更新-要使子部分优先于部分,您需要反转IF/ELSE条件。
if ( !empty($_GET['sId']) && !empty($_GET['ssId']) ) {
//load and show content for sub section if availavle
} else if ( !empty($_GET['sId']) ) {
//load and show content for section
}