HTML
<?php $var = 1; include('PHP/NavigationBar.php'); ?>
Navigation.php
<div class="sidenav">
<h5>JavaScript</h5>
<button class="w3-button w3-theme w3-block w3-left-align w3-padding-small"
onclick="myAccFunc('1')"> Main Heading <i class="fa fa-caret-down"></i></button>
<div id="1" class="w3-blue w3-hide w3-card" >
<a class="<?php echo (($var==1)?'active':'');?>" href="Page1.php">Page 1</a>
<a class="<?php echo (($var==2)?'active':'');?>" href="Page2.php">Page 2</a>
<a class="<?php echo (($var==3)?'active':'');?>" href="Page3.php">Page 3</a>
<a class="<?php echo (($var==4)?'active':'');?>" href="Page4.php">Page 4</a>
</div>
</div>
这是我的导航菜单。当前只有4个项目,而Class =“ Active”表示活动页面因此,如果用户位于第2页,则导航中的第2页将以该类突出显示
这完全可以正常工作,但是我必须从PHP转到JavaScript
因此HTML行变成
<script type="text/javascript" src="PHP/Navigation.js"></script>
我可以通过window.location.href获取当前URL如何将其传递给JS文件,以及如何在JS文件(当前为PHP文件)中包含HTML内容?
我已将所有Web链接放入JS文件中的数组中。因此,接下来我该怎么做才能实现使用PHP和HTML以及JavaScript和HTML所实现的相同功能。
我只需要导入Nav菜单并使用JavaScript突出显示当前站点
我花了一些时间来理解您的期望,但现在这里是您的Navigation.js
var activeClass = new Array(4);
if(window.location.href.includes('Page1.php')) {
activeClass[0] = 'active';
} else if(window.location.href.includes('Page2.php')) {
activeClass[1] = 'active';
} else if(window.location.href.includes('Page3.php')) {
activeClass[2] = 'active';
} else if(window.location.href.includes('Page4.php')) {
activeClass[3] = 'active';
}
document.write('<div class="sidenav"><h5>JavaScript</h5>'+
'<button class="w3-button w3-theme w3-block w3-left-align w3-padding-small" onclick="myAccFunc(1)">'+
' Main Heading <i class="fa fa-caret-down"></i></button><div id="1" class="w3-blue w3-hide w3-card" >');
document.write('<a class="'+activeClass[0]+'" href="Page1.php">Page 1</a>');
document.write('<a class="'+activeClass[1]+'" href="Page2.php">Page 2</a>');
document.write('<a class="'+activeClass[2]+'" href="Page3.php">Page 3</a>');
document.write('<a class="'+activeClass[3]+'" href="Page4.php">Page 4</a>');
document.write('</div></div>');