Это должен быть довольно простой вопрос, но я бросил большую часть своего утра на это, и в этот момент я близок к тому, чтобы бросить полотенце. У меня нет даже немного JS обув - но я нашел хорошо комментировал кусок кода, который я надеялся использовать для анимации якорь ссылки это:Учет фиксированного заголовка с анимацией. Scrolltop и (target) .offset(). Top;
$(document).ready(function() {
$('a[href*=#]').bind('click', function(e) {
e.preventDefault(); //prevent the "normal" behaviour which would be a "hard" jump
var target = $(this).attr("href"); //Get the target
var scrollToPosition = $(target).offset().top;
// perform animated scrolling by getting top-position of target-element and set it as scroll target
$('html, body').stop().animate({ scrollTop: scrollToPosition}, 600, function() {
location.hash = target; //attach the hash (#jumptarget) to the pageurl
});
return false;
});
});
Я пытаюсь получить его земля 30px выше верхнего смещения() -. Я попытался
$('html, body').stop().animate({ scrollTop: scrollToPosition -30}, 600,
Который почти работает - он идет в нужном месте, но затем отскакивает назад.
Я также попытался
scrollTop: $(target).offset().top - 20 },
Я также попытался
scrollTop: $(hash).offset().top + $('#access').outerHeight()
Который не кажется ничего менять.
Кажется, что ответ может быть здесь: JQuery page scroll issue with fixed header, но я просто не могу, похоже, получить его.
Я знаю, что это похоже на другие вопросы - но я прошел через то, что мог найти, и я недостаточно грамотен, чтобы не копировать/вставлять все, что исправляет проблему.
Я был бы невероятно благодарен за решение.
Большое спасибо,
Martin
PS
Этот другой кусок кода, который я нашел работу, но делает это зачистки хэштегом из, что делает это в основном бесполезно.
$(function(){
$('a[href*=#]').click(function() {
if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'')
&& location.hostname == this.hostname) {
var $target = $(this.hash);
$target = $target.length && $target || $('[name=' + this.hash.slice(1) +']');
if ($target.length) {
var targetOffset = $target.offset().top;
$('html,body').animate({scrollTop: targetOffset - 30}, 1000);
return false;
}
}
});
});
Большое спасибо Стиву. Клянусь, я собираюсь узнать достаточно, чтобы понять, что я копирую, и надеюсь, в этом году, но это только спасло меня от головных болей. Cheers -m – Martin
Быстрый вопрос: код работает отлично, но хэш, добавленный к URL, подходит как «#undefined» - любые идеи? – Martin
Не беспокойтесь. Просто держитесь за это, регулярно посещайте онлайн-учебники, и вы будете впитывать знания, которые вам нужны! Defo проверяет сайты tutsplus ([Webdesigntuts] (http://webdesign.tutsplus.com/), [Nettuts] (http://net.tutsplus.com/)) и [Team Treehouse] (http: // teamtreehouse .com /) веб-дизайн/разработка обучения от Carsonified, все большие бесплатные ресурсы. –