2017-02-03 2 views
0

Я строю сайт с помощью Wordpress. Большинство ссылок на навигационное меню ссылаются на идентификатор на главной странице. Поэтому, когда я загружаю свой сайт, все ссылки, которые ссылаются на место на главной странице, в настоящее время активны. Я удалил скрипт в Wordpress, который проверяет, активен ли он. Я решил, что могу использовать bootstrap scrollspy, чтобы это сделать или даже этот JSFiddle https://jsfiddle.net/cse_tushar/Dxtyu/141/Wordpress меняет активный класс на bootstrap nav во время зависания

Проблема, с которой я сталкиваюсь, заключается в том, что навигация выплевывается Wordpress. У меня нет возможности войти и на самом деле жесткий код «активный» к первому элементу li, а затем сделать класс add и удалить класс. Как я могу изменить вышеупомянутый JSFiddle, чтобы он сделал хэш-цель. Поэтому всякий раз, когда я прокручиваю и ударяю div с тем же идентификатором, что и элемент nav, он запускает активный класс и остается активным до тех пор, пока я не удалю другого или не сменит страницы. Вот что мой навигатор выглядит на WordPress.

<nav class="collapse navbar-collapse" role="navigation"> 
     <ul id="menu-primary-navigation" class="nav navbar-nav"> 
      <li class="current-menu-item current_page_item menu-about"><a href="/#about">About</a></li> 
      <li class="current-menu-item current_page_item menu-team"><a href="/#team">Team</a></li> 
      <li class="current-menu-item current_page_item menu-services"><a href="/#services">Services</a></li> 
      <li class="menu-services"><a href="/blog">Blog</a></li> 
      <li class="current-menu-item current_page_item menu-contact-us"><a href="/#contact">Contact Us</a></li> 
     </ul>  
</nav> 

<div id="about"> 
    Something Here 
</div> 

<div id="team"> 
    Something Here 
</div> 

ответ

0

Вы можете выполнить это, добавив следующую строку в начале загрузки страницы:

$("ul li a:first").addClass('active'); 

$(document).ready(function() { 
 
    $(document).on("scroll", onScroll); 
 
    $("ul li a:first").addClass('active'); 
 
    
 
    //smoothscroll 
 
    $('a[href^="#"]').on('click', function (e) { 
 
     e.preventDefault(); 
 
     $(document).off("scroll"); 
 
     
 
     $('a').each(function() { 
 
      $(this).removeClass('active'); 
 
     }) 
 
     $(this).addClass('active'); 
 
     
 
     var target = this.hash, 
 
      menu = target; 
 
     $target = $(target); 
 
     $('html, body').stop().animate({ 
 
      'scrollTop': $target.offset().top+2 
 
     }, 500, 'swing', function() { 
 
      window.location.hash = target; 
 
      $(document).on("scroll", onScroll); 
 
     }); 
 
    }); 
 
}); 
 

 
function onScroll(event){ 
 
    var scrollPos = $(document).scrollTop(); 
 
    $('#menu-center a').each(function() { 
 
     var currLink = $(this); 
 
     var refElement = $(currLink.attr("href")); 
 
     if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) { 
 
      $('#menu-center ul li a').removeClass("active"); 
 
      currLink.addClass("active"); 
 
     } 
 
     else{ 
 
      currLink.removeClass("active"); 
 
     } 
 
    }); 
 
}
body, html { 
 
    margin: 0; 
 
    padding: 0; 
 
    height: 100%; 
 
    width: 100%; 
 
} 
 
.menu { 
 
    width: 100%; 
 
    height: 75px; 
 
    background-color: rgba(0, 0, 0, 1); 
 
    position: fixed; 
 
    background-color:rgba(4, 180, 49, 0.6); 
 
    -webkit-transition: all 0.3s ease; 
 
    -moz-transition: all 0.3s ease; 
 
    -o-transition: all 0.3s ease; 
 
    transition: all 0.3s ease; 
 
} 
 
.light-menu { 
 
    width: 100%; 
 
    height: 75px; 
 
    background-color: rgba(255, 255, 255, 1); 
 
    position: fixed; 
 
    background-color:rgba(4, 180, 49, 0.6); 
 
    -webkit-transition: all 0.3s ease; 
 
    -moz-transition: all 0.3s ease; 
 
    -o-transition: all 0.3s ease; 
 
    transition: all 0.3s ease; 
 
} 
 
#menu-center { 
 
    width: 980px; 
 
    height: 75px; 
 
    margin: 0 auto; 
 
} 
 
#menu-center ul { 
 
    margin: 15px 0 0 0; 
 
} 
 
#menu-center ul li { 
 
    list-style: none; 
 
    margin: 0 30px 0 0; 
 
    display: inline; 
 
} 
 
.active { 
 
    font-family:'Droid Sans', serif; 
 
    font-size: 14px; 
 
    color: #fff; 
 
    text-decoration: none; 
 
    line-height: 50px; 
 
} 
 
a { 
 
    font-family:'Droid Sans', serif; 
 
    font-size: 14px; 
 
    color: black; 
 
    text-decoration: none; 
 
    line-height: 50px; 
 
} 
 
#home { 
 
    background-color: grey; 
 
    height: 100%; 
 
    width: 100%; 
 
    overflow: hidden; 
 
    background-image: url(images/home-bg2.png); 
 
} 
 
#portfolio { 
 
    background-image: url(images/portfolio-bg.png); 
 
    height: 100%; 
 
    width: 100%; 
 
} 
 
#about { 
 
    background-color: blue; 
 
    height: 100%; 
 
    width: 100%; 
 
} 
 
#contact { 
 
    background-color: red; 
 
    height: 100%; 
 
    width: 100%; 
 
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.1/jquery.min.js"></script> 
 
<div class="m1 menu"> 
 
    <div id="menu-center"> 
 
     <ul> 
 
      <li><a href="#home">Home</a> 
 

 
      </li> 
 
      <li><a href="#portfolio">Portfolio</a> 
 

 
      </li> 
 
      <li><a href="#about">About</a> 
 

 
      </li> 
 
      <li><a href="#contact">Contact</a> 
 

 
      </li> 
 
     </ul> 
 
    </div> 
 
</div> 
 
<div id="home"></div> 
 
<div id="portfolio"></div> 
 
<div id="about"></div> 
 
<div id="contact"></div>

Смежные вопросы