
这段代码首先尝试从 request_uri 获取 url,如果不存在则尝试从 script_name 获取,最后使用 pathinfo 函数提取文件名。
步骤 2:在导航菜单中添加条件判断
接下来,在你的导航菜单模板中,为每个菜单项添加一个条件判断,检查当前文件名是否与该菜单项的链接匹配。如果匹配,则添加一个特定的CSS类,例如 current-menu active。
<a href="team.php" class="list-group-item list-group-item-action py-2 ripple bg-button<?php if (stripos($thisFile, 'team.php') !== false) {echo ' current-menu active';} ?>">
  <i class="fas fa-users fa-fw me-3"></i><span>Our team</span>
</a>在这个例子中,如果 $thisFile 包含 "team.php",则 current-menu active 类将被添加到 <a> 标签中。
如果你的网站结构更复杂,例如在子目录中包含相同的文件名,那么简单的文件名匹配可能不够准确。 例如,你有 team.php 和 support/team.php 两个文件。
立即学习“PHP免费学习笔记(深入)”;
步骤 1:获取完整的URL
与方法一类似,首先获取当前URL。
<?php $thisUrl = (isset($_SERVER['REQUEST_URI']) ? $_SERVER['REQUEST_URI'] : (isset($_SERVER['SCRIPT_NAME']) ? $_SERVER['SCRIPT_NAME'] : null)); $thisFile = pathinfo($thisUrl , PATHINFO_BASENAME); ?>
步骤 2:在导航菜单中添加更精确的条件判断
在导航菜单中,使用更精确的条件判断来区分相同文件名的不同链接。
<!-- 精确匹配 file.php -->
<a href="team.php" class="list-group-item list-group-item-action py-2 ripple bg-button<?php if ('team.php' === $thisFile)) {echo ' current-menu active';} ?>">...</a>
<!-- 匹配 /path/file.php -->
<a href="support/team.php" class="list-group-item list-group-item-action py-2 ripple bg-button<?php if (stripos($thisUrl, 'support/team.php') !== false) {echo ' current-menu active';} ?>">...</a>在这个例子中,第一个链接使用 === 进行严格的文件名匹配,而第二个链接使用 stripos 检查URL是否包含 "support/team.php"。
为了使高亮效果可见,你需要添加相应的CSS样式。 例如:
.current-menu {
  border-left: 5px solid #blue; /* 添加左边框 */
  font-weight: bold; /* 加粗字体 */
}
.active {
  background-color: #f0f0f0; /* 改变背景颜色 */
}你可以根据你的网站设计自定义这些样式。
通过使用PHP和CSS,我们可以轻松地实现导航菜单的高亮显示功能。 无论你的网站结构简单还是复杂,都可以根据本文提供的两种方法找到适合你的解决方案。 记住,清晰的导航对于用户体验至关重要,高亮显示当前页面可以帮助用户更好地理解网站结构。
以上就是使用PHP高亮当前页面导航菜单的详细内容,更多请关注php中文网其它相关文章!
                        
                        PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号