У меня есть этот код для навигации, прокрутите до раздела.
var lastId;
var topMenu = $(".community-nav");
var topMenuHeight = topMenu.outerHeight() - 19;
if(window.matchMedia("(max-width: 768px)").matches){
var logoHeight = $(".community-logo").outerHeight();
var topMenuHeight = topMenu.outerHeight() - logoHeight;
};
menuItems = topMenu.find('.community-links li > div'),
scrollItems = $('.nav-section')
menuItems.click(function(e){
var href = $(this).attr("data-target");
var currentItem = $(this);
var sectionClass = $("#community-intranav");
scrollPartialMenuItem(currentItem, sectionClass);
var offsetTop = href === "#" ? 0 : $(href).offset().top-topMenuHeight + 20;
if(window.matchMedia("(max-width: 768px)").matches){
};
$('html, body').stop().animate({
scrollTop: offsetTop
}, 850);
e.preventDefault();
});
function getCurrentSection(scrollPosition) {
return scrollItems.toArray().findIndex(function(item) {
return item.offsetTop < scrollPosition && item.offsetTop+item.clientHeight > scrollPosition;
});
}
// Bind to scroll
$(window).on("load scroll",function(e){
var scrollPosition = $(this).scrollTop()+topMenuHeight;
var currentSection = getCurrentSection(scrollPosition) ;
var id = currentSection > -1 ? scrollItems[currentSection].id : "";
if (id && lastId !== id) {
lastId = id;
menuItems.removeClass("active");
menuItems.filter("[data-target='#"+id+"']").addClass('active');
}
});
В приведенном выше коде метод findIndex поддерживается в IE. Я хочу альтернативу для того же, чтобы я мог переписать свою функцию getCurrentSectionиспользуя что-то отличное от метода findIndex. Пожалуйста, помогите.