在JavaScript(.js)文件中包含HTML



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内容?

我已经把所有的链接放在JS文件中的数组中。那么,我接下来该怎么做才能实现我使用PHP和HTML但使用JavaScript和HTML实现的相同目标呢。

我只需要导入导航菜单并使用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>');

最新更新