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

问题描述 投票:-1回答:1

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突出显示当前站点

javascript php html css browser
1个回答
2
投票

我花了一些时间来理解您的期望,但现在这里是您的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>');
© www.soinside.com 2019 - 2024. All rights reserved.