2013-07-25 61 views
0

我正在創建一個單頁的網站。平滑滾動jquery +固定導航錯誤

我遇到了在頂部應用平滑滾動以及固定菜單的問題。 當我點擊鏈接時,菜單消失並出現錯誤。

下面是該網站與錯誤: http://bitcast.com.br/

我使用平滑滾動效果的JavaScript代碼如下(從CSSTricks.com):

<script type="text/javascript"> 
$(document).ready(function() { 
    function filterPath(string) { 
    return string 
    .replace(/^\//,'') 
    .replace(/(index|default).[a-zA-Z]{3,4}$/,'') 
    .replace(/\/$/,''); 
    } 
    var locationPath = filterPath(location.pathname); 
    var scrollElem = scrollableElement('html', 'body'); 

    $('a[href*=#]').each(function() { 
    var thisPath = filterPath(this.pathname) || locationPath; 
    if ( locationPath == thisPath 
    && (location.hostname == this.hostname || !this.hostname) 
    && this.hash.replace(/#/,'')) { 
     var $target = $(this.hash), target = this.hash; 
     if (target) { 
     var targetOffset = $target.offset().top; 
     $(this).click(function(event) { 
      event.preventDefault(); 
      $(scrollElem).animate({scrollTop: targetOffset}, 800, function() { 
      location.hash = target; 
      }); 
     }); 
     } 
    } 
    }); 

    // use the first element that is "scrollable" 
    function scrollableElement(els) { 
    for (var i = 0, argLength = arguments.length; i <argLength; i++) { 
     var el = arguments[i], 
      $scrollElement = $(el); 
     if ($scrollElement.scrollTop()> 0) { 
     return el; 
     } else { 
     $scrollElement.scrollTop(1); 
     var isScrollable = $scrollElement.scrollTop()> 0; 
     $scrollElement.scrollTop(0); 
     if (isScrollable) { 
      return el; 
     } 
     } 
    } 
    return []; 
    } 

}); 
</script> 

回答

0

如果刪除

function() { 
      location.hash = target; 
      } 

滾動動畫,它會正常工作。

+0

它似乎在工作。 Awesooome。非常感謝你! – juanpazos

+0

如果希望更改哈希,您還可以更改導航欄的z索引以刷新它。 – L105