From 8c4d6cec338df1bf45e205c9b0f5d31c6ada3d05 Mon Sep 17 00:00:00 2001 From: Tomiwa Adefokun Date: Wed, 2 Mar 2016 19:36:35 +0100 Subject: [PATCH] Update jquery.nav.js Filter $nav to exclude links that don't have #hash and also changed the getSection to return the section at the maximum position. --- jquery.nav.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/jquery.nav.js b/jquery.nav.js index 1296443..98b4730 100644 --- a/jquery.nav.js +++ b/jquery.nav.js @@ -16,7 +16,9 @@ * scrollSpeed: 750 * }); */ - +var navFilter = function(index, link){ + return $(link).attr('href').split('#')[1] != undefined; +}; ;(function($, window, document, undefined){ // our plugin constructor @@ -39,7 +41,7 @@ currentClass: 'current', changeHash: false, easing: 'swing', - filter: '', + filter: navFilter, scrollSpeed: 750, scrollThreshold: 0.5, begin: false, @@ -73,7 +75,6 @@ return this; }, - adjustNav: function(self, $parent) { self.$elem.find('.' + self.config.currentClass).removeClass(self.config.currentClass); $parent.addClass(self.config.currentClass); @@ -127,11 +128,14 @@ getSection: function(windowPos) { var returnValue = null; + var prevPosition = null; var windowHeight = Math.round(this.$win.height() * this.config.scrollThreshold); - for(var section in this.sections) { if((this.sections[section] - windowHeight) < windowPos) { - returnValue = section; + if(prevPosition == null || prevPosition < this.sections[section]){ + prevPosition = this.sections[section]; + returnValue = section; + } } } @@ -220,4 +224,4 @@ }); }; -})( jQuery, window , document ); \ No newline at end of file +})( jQuery, window , document );