Questa dovrebbe essere una domanda piuttosto semplice, ma ho gettato la maggior parte della mia mattinata a questo punto, ea questo punto sono vicino a gettare la spugna. Non ho nemmeno un po 'di foo js - ma ho trovato un pezzo ben commentato di codice che spero di utilizzare per animare ancora la collega è:Contabilizzazione di un'intestazione fissa con animate.scrolltop e (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;
});
});
sto cercando di farlo 30px terreno sopra l'offset() in alto -. ho provato
$('html, body').stop().animate({ scrollTop: scrollToPosition -30}, 600,
cui quasi funziona - va al posto giusto, ma poi si riprende.
Ho anche provato
scrollTop: $(target).offset().top - 20 },
Ho anche provato
scrollTop: $(hash).offset().top + $('#access').outerHeight()
che non sembra cambiare nulla.
Sembra che la risposta potrebbe essere qui: JQuery page scroll issue with fixed header ma non riesco proprio a capirlo.
So che questo è simile ad altre domande - ma ho esaminato ciò che ho potuto trovare e sono abbastanza analfabeta da non essere stato in grado di copiare/incollare qualsiasi cosa risolva il problema.
Sarei incredibilmente grato per una soluzione.
Molte grazie,
Martin
PS
Questo altro pezzo di codice che ho trovato funziona ma è nudo l'hashtag, il che rende per lo più inutili.
$(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;
}
}
});
});
Grazie mille Steve. Giuro che imparerò a sufficienza per capire cosa sto facendo di copia e di sperimentazione, spero che quest'anno, ma questo mi abbia solo risparmiato il mal di testa. Cheers -m – Martin
Domanda veloce: il codice funziona perfettamente, ma l'hash aggiunto all'URL sta diventando "#undefined" - qualche idea? – Martin
Nessun problema amico. Continua a farlo, fai regolarmente dei buoni tutorial online e ti immergi nelle tue conoscenze! Scopri i siti Web tutsplus ([Webdesigntuts] (http://webdesign.tutsplus.com/), [Nettuts] (http://net.tutsplus.com/)) e [Team Treehouse] (http: // teamtreehouse .com /) web design/sviluppo apprendimento da Carsonified, tutte grandi risorse gratuite. –