W miarę przewijania strony w dół zmienia się aktywny element menu. Jak to się robi?
95
Odbywa się to poprzez powiązanie ze zdarzeniem przewijania kontenera (zwykle oknem).
Szybki przykład:
// Cache selectors
var topMenu = $("#top-menu"),
topMenuHeight = topMenu.outerHeight()+15,
// All list items
menuItems = topMenu.find("a"),
// Anchors corresponding to menu items
scrollItems = menuItems.map(function(){
var item = $($(this).attr("href"));
if (item.length) { return item; }
});
// Bind to scroll
$(window).scroll(function(){
// Get container scroll position
var fromTop = $(this).scrollTop()+topMenuHeight;
// Get id of current scroll item
var cur = scrollItems.map(function(){
if ($(this).offset().top < fromTop)
return this;
});
// Get the id of the current element
cur = cur[cur.length-1];
var id = cur && cur.length ? cur[0].id : "";
// Set/remove active class
menuItems
.parent().removeClass("active")
.end().filter("[href='#"+id+"']").parent().addClass("active");
});
Zobacz powyższe w akcji w jsFiddle, w tym animację przewijania.
menuItems = topMenu.find("a"),
sięmenuItems = topMenu.find("a").slice(0,4),
, zastępując4
z [Twoje na stronie linki - 1].Po prostu sprawdź mój Kod i Snajpera i link demo:
demo na żywo
Pokaż fragment kodu
źródło
Tylko jako uzupełnienie odpowiedzi @Marcus Ekwall. W ten sposób uzyskasz tylko linki kotwiące. I nie będziesz mieć problemów, jeśli masz mieszankę linków kotwicznych i zwykłych.
Zasadniczo wymieniłem
przez
Aby dopasować wszystkie linki do zakotwiczenia gdzieś i zmienić wszystko, co było konieczne, aby działało z tym
Zobacz to w akcji na jsfiddle
źródło
Jeśli chcesz, aby zaakceptowana odpowiedź działała w JQuery 3, zmień kod w ten sposób:
Dodałem również try-catch, aby zapobiec awariom javascript, jeśli nie ma elementu o tym identyfikatorze. Zapraszam do ulepszania go jeszcze bardziej;)
źródło