2017-02-16 83 views
1

我想把我的菜單放在一個單獨的PHP文件中,所以當我需要編輯它時,我只需要編輯它一次。當我想突出顯示活動頁面時,問題就開始了。有人可以幫我解決它嗎?PHP菜單活動「這裏」鏈接

<?php $currentPage = basename($_SERVER['SCRIPT_FILENAME']); ?> 

切換導航

     <li><a href="index.php" <?php if ($currentPage == 'index.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-home"></span> Home</a></li> 
         <li><a href="about.php" <?php if ($currentPage == 'about.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-picture"></span> About us</a></li> 
         <li class="dropdown"> 
          <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false"> <span class="glyphicon glyphicon-calendar"></span> Services <span class="caret"></span></a> 
          <ul class="dropdown-menu"> 
           <li><a href="services1.php" <?php if ($currentPage == 'services1.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-user"></span> Drivers services</a></li> 
           <li><a href="services2.php" <?php if ($currentPage == 'services2.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-wrench"></span> Shop services</a></li> 
          </ul> 
         </li> 

         <li><a href="application.php"<?php if ($currentPage == 'application.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-pencil"></span> On-line Application</a></li> 
         <li><a href="contact.php" <?php if ($currentPage == 'contact.php') { echo 'id="here"'; }?>><span class="glyphicon glyphicon-envelope"></span> Contact us</a></li> 

        </ul> 

       </div><!-- /.navbar-collapse --> 
      </div><!-- /.container-fluid --> 
     </nav> 
     <div class="clearfix"> </div> 
    </div><!-- navbar --> 
+1

修復呢?你沒有告訴我們這個問題 – nogad

+0

如果你把它放在一個單獨的文件中會發生什麼? 'basename($ _ SERVER ['SCRIPT_FILENAME'])'仍應該返回您正在查找的腳本名稱。 – jrn

+0

@nogad當我懸停菜單時,它不會突出顯示活動頁面。 –

回答

0

我找到解決我的問題加入這個CSS樣式中的文件:

/* The here ID identifies the current page and applies a white color to the text and a black background as a visual indicator. */ 
 

 
a#here { 
 
    background-color: #000 !important; 
 
    color: #fff !important; 
 
}

加上調用與下面的代碼在每一頁菜單:

<div> <?php 
       $file ='includes/menu.php'; 
       if (file_exists($file) && is_readable($file)) { 
       include($file); 
       } else { 
        throw new Exception("$file can't be found"); 
        } 
       include('includes/menu.php');?> 
    </div>  
-1

一個快速和骯髒的方法來實現這一目標是在每個文件把下面的:

<?php 
    include("header.php"); // Insert location of header file here 
?> 

,並在創建後您的header.php文件你的頭塊插入此

<?php $active= substr(basename($_SERVER['SCRIPT_FILENAME']),0, -4); ?> // Page Name 
<body <?php echo "class='$active'";?>> // This sets the bodies class to be the page name. 

終於在style.css中使用下面的代碼來設置突出特點

// This is an example for my CSS. Insert your own css selector 

// In my css i have this which adds a small orange bar to the bottom of the navigation option. I set the opacity to 0 to not display it. 
.header nav ul li a:before 
{ 
    height: 5px; 
    background: #ea5c18; 
    opacity: 0; 
} 
// Then i set .PageName (the bodies class name) and set that specific nav element to have an opacity of 1. 
.PageName .header nav ul li:first-child a:before 
{ 
    opacity:1; 
} 
+0

髒是正確的,當你可以用$ _SERVER變量檢測頁面時, – nogad

+0

是的,忘了那個。編輯我的答案@nogad –

+0

多數民衆贊成在OP已經有 – nogad

相關問題