0

我在JS代碼中有一個奇怪的錯誤。使用簡單的I18n翻譯我的菜單按鈕後,通過單擊「English |Русский」將頁面翻譯爲其他語言後,我的菜單按鈕不能正常工作,直到我重新加載頁面。我認爲理由 - 是負責菜單滾動的JS代碼。 但我不明白真正的原因。javascript事件中的錯誤/ rails應用程序

<!-- start-smoth-scrolling--> 
<script type="text/javascript"> 
    jQuery(document).ready(function($) { 
     $(".scroll").click(function(event){ 
     event.preventDefault(); 

    $('html,body').animate({scrollTop:$(this.hash).offset().top},1000); 
     }); 
    }); 
</script> 
<!--//end-smoth-scrolling--> 



<!--banner--> 
     <div id="home" class="banner"> 
     <div class="banner-info"> 
      <div class="banner-top"> 
      <div class="container"> 
       <div class="col-md-6 banner-top-left wow slideInDown animated" data-wow-delay=".5s"> 
       <ul class="social-icons"> 
        <li><a href="#"> </a></li> 
        <li><a href="#" class="fb"> </a></li> 
        <li><a href="#" class="in"> </a></li> 
        <li><a href="#" class="dott"> </a></li> 
       </ul> 
       </div> 
       <div class="col-md-6 banner-top-right wow slideInDown animated" data-wow-delay=".5s"> 
       <p><span class="glyphicon glyphicon-earphone"></span> +7 978 887 34 61 </p> 
       <p><%= link_to_unless_current "English", locale: "en" %> | <%= link_to_unless_current "Русский", locale: "ru" %></p> 
       </div> 
       <div class="clearfix"> </div> 
      </div> 
      </div> 
      <div class="banner-text"> 
      <h1 class="wow slideInLeft animated" data-wow-delay=".5s"><%= t "banner.title" %></h1> 
      <p class="wow slideInRight animated" data-wow-delay=".5s"><%= t "banner.description" %></p> 
      </div> 
      <!--navigation--> 
      <div class="top-nav wow"> 
      <div class="container"> 
       <div class="navbar-header logo"> 
       <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1"><%= t "navigation.menu" %> 
       </button> 
       </div> 
       <!-- Collect the nav links, forms, and other content for toggling --> 
       <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1"> 
       <div class="menu"> 
        <ul class="nav navbar"> 
        <li class="menu-item menu-item-current"><a href="#home" class="menu-link scroll"><%= t "navigation.home" %></a></li> 
        <li class="menu-item"><a href="#about" class="menu-link scroll"><%= t "navigation.about" %></a></li> 
        <li class="menu-item"><a href="#services" class="menu-link scroll"><%= t "navigation.services" %></a></li> 
        <li class="menu-item"><a href="#work" class="menu-link scroll"><%= t "navigation.works" %></a></li> 
        <li class="menu-item"><a href="#gallery" class="menu-link scroll"><%= t "navigation.gallery" %></a></li> 
        <li class="menu-item"><a href="#contact" class="menu-link scroll"><%= t "navigation.contact" %></a></li> 
        </ul> 
       </div> 
       <div class="clearfix"> </div> 
       <script> 
        (function() { 
        [].slice.call(document.querySelectorAll('.menu')).forEach(function(menu) { 
         var menuItems = menu.querySelectorAll('.menu-link'), 
         setCurrent = function(ev) { 
          ev.preventDefault(); 

          var item = ev.target.parentNode; // li 

          // return if already current 
          if(classie.has(item, 'menu-item-current')) { 
          return false; 
          } 
          // remove current 
          classie.remove(menu.querySelector('.menu-item-current'), 'menu-item-current'); 
          // set current 
          classie.add(item, 'menu-item-current'); 
         }; 

         [].slice.call(menuItems).forEach(function(el) { 
         el.addEventListener('click', setCurrent); 
         }); 
        }); 
        })(window); 
       </script> 
       </div> 
       <!-- script-for sticky-nav --> 
       <script> 
       $(document).ready(function() { 
       var navoffeset=$(".top-nav").offset().top; 
       $(window).scroll(function(){ 
        var scrollpos=$(window).scrollTop(); 
        if(scrollpos >=navoffeset){ 
        $(".top-nav").addClass("fixed"); 
        }else{ 
        $(".top-nav").removeClass("fixed"); 
        } 
       }); 

       }); 
       </script> 
       <!-- /script-for sticky-nav --> 
      </div> 
      </div> 
      <!--//navigation--> 
     </div> 
     </div> 
     <!--//banner--> 

回答

0

我發現這個問題JQuery gets loaded only on page refresh in Rails 4 application 的問題是在turbolinks資產的解決方案。 JS只在我重新加載頁面時才起作用。 感謝Ian和他的回答。

刪除// =需要從資產/ Java腳本/ application.js中文件turbolinks:

在你的Gemfile

,這對你的資產/ JavaScript的添加寶石 'jQuery的turbolinks'/ application.js中的文件:

// =要求jquery.turbolinks