I am fairly new to using PHP, before this navigation the extent of my PHP use was simple includes.
I have written a navigation.php file that generates links for a navigation dynamically using variables pulled from an array inside variables.php
The overall goal is to add/subtract links, subnavs, sub-subnavs, sub-sub-subnavs only by editing variables.php
The method I am using to generate the HTML structure feels clunky to me, it works just fine but I feel like there is a simpler way of doing this...
Also, I require additional styling for any LI that has a subnav present (an arrow to indicate a subnav is present). I would like to generate that dynamically.
That said my questions are:
- Is there a simpler way of doing this?
- Is there a way to generate my 's dynamically based on whether there is a sub-nav present?
Each page has the following code, it changes depending on the page.
<?php $title = 'Home'; ?>
My variables.php :
<!-- NAVIGATION ARRAY -->
<?php
$nav_mini = array(
'Home' => 'index.php',
'About' => 'about.php',
'Services' => 'services.php'
);
?>
<?php
$nav_main = array(
'Home' => 'index.php',
'About' => 'about.php',
'Services' => 'services.php',
'Portfolio' => 'contact.php',
'Clients' => 'about.php',
'Gallery' => 'services.php',
'News' => 'services.php',
'Contact Us' => 'contact.php'
);
?>
<?php // SUB NAV ARRAYS
$nav_sub_about = array(
'Our Team' => 'about.php'
);
$nav_sub_michael = array(
'Michael' => 'index.php',
'Aaron' => 'about.php',
'Kenny' => 'about.php',
'David' => 'about.php'
);
$nav_sub_services = array(
'Get Found' => 'about.php'
);
?>
Navigation PHP File main-nav.php
<?php
foreach ( $nav_main as $key => $value ) {
echo "<li><a ";
echo "class='"; // STARTS CLASS=
if ( $title == $key) {
echo "active "; }// ADDS ACTIVE CLASS TO LINK OF CURRENT PAGE
echo "' "; // END QUOTES FOR CLASS="
echo "href='$value'>$key";
if ( $key == "About") { // STARTS IF SEQUENCE FOR SUBNAV ARROWS
echo "<span class='arrow'> +</span>";}
elseif ( $key == "Services") {
echo "<span class='arrow'> +</span>";}
echo "</a>\n"; // END ANCHOR TAG FOR MAIN NAV LINKS
//----------------------------------------------------------------------------------------------------------//
// PLEASE START SUB-NAVS HERE ------------------------------------------------------------------------------//
// AT THIS POINT A NEW <LI> IS GENERATED FROM THE FIRST FOREACH, IF THE BELOW IS TRUE IT POPULATES A SUBNAV //
if ( $key == "About"){ // START SUBNAV FOR ABOUT
echo "<ul class='main-sub-nav'>"; // THIS LINE WAS ADDED TO START THE <UL> FOR THE SUBNAV, IT ENDS ON LINE 14
foreach ( $nav_sub_about as $key => $value ) {
echo "<li><a href='$value'>$key";
if ( $key == "Our Team") { // STARTS IF SEQUENCE FOR SUBNAV ARROWS
echo "<span class='arrow'> +</span>";}
echo "</a>\n"; // ENDS ANCHOR TAG FROM SUBNAV LI
// SUB-SUB-NAV STARTS HERE
if ( $key == 'Our Team') {
echo "<ul class='main-sub-sub-nav'>"; // THIS STARTS THE UL FOR SUB-SUB-NAV
foreach ($nav_sub_michael as $key => $value ) {
echo "<li><a href='$value'>$key</a></li>\n";
}
echo "</ul>"; // THIS ENDS THE SUB-SUB-NAV UL STARTED ON LINE 34
echo "</li>";}// THIS IS THE END IF <LI> FROM THE SECOND FOREACH ON LINE 35
}
echo "</ul>"; // THIS WAS ADDED TO END THE SUBNAV <UL> STARTED ON LINE 11
echo "</li>";} // THIS IS THE END OF THE <LI> FROM THE FIRST FOREACH ECHO FROM LINE 8
//----------------------------------------------------------------------------------------------------------//
// AT THIS POINT A NEW <LI> IS GENERATED FROM THE FIRST FOREACH, IF THE BELOW IS TRUE IT POPULATES A SUBNAV //
if ( $key == "Services"){
echo "<ul class='main-sub-nav'>"; // THIS LINE WAS ADDED TO START THE <UL> FOR THE SUBNAV, IT ENDS ON LINE 14
foreach ( $nav_sub_services as $key => $value ) {
echo "<li><a href='$value'>$key</a></li>\n";}
echo "</ul>"; // THIS WAS ADDED TO END THE SUBNAV <UL> STARTED ON LINE 11
echo "</li>";} // THIS IS THE END OF THE <LI> FROM THE FIRST FOREACH ECHO FROM LINE 8
} // THIS BRACKET ENDS THE ENTIRE SET OF PHP. ITS PAIR IS ON LINE 19
?>
The overall goal is to add/subtract links, subnavs, sub-subnavs, sub-sub-subnavs only by editing variables.php
Here is a live example of this nav structure working... http://khill.mhostiuckproductions.com/siteLSSBoilerPlate/