Hallo,
ich bin gerade dabei Javascript etwas intensiver zu lernen und stelle mir dabei selbst Aufgaben, bei denen es nur darum geht, die richtige Denkweise dafür zu trainieren.
Ich möchte ein Script basteln, dass egal welche Seite man hat und wie lang sie ist, automatisch erkennt, wohin gescrollt ist und dann "smooth", zumindest so halbwegs (besser als ein sprung), nach oben scrollt.
Dafür habe ich ein eigenes Script gebastelt:
Mein Problem dabei ist, dass, wenn fertig nach oben gescrollt ist, das script irgendwie noch immer aktiv bleibt, also sobald man herunterscrollt wieder hochgescrollt wird. Eigentlich sollte der Intervall mit clearInterval doch beendet sein, sobald der Stand des Scrollens unter 10 fällt - wird er aber nicht.
Also wie gesagt, das ist alles nur zum Trainingszweck, ich will das nicht einsetzen, aber es würde mich schon interessieren, wie man das lösen kann.
Also, ich würde mich wirklich sehr freuen, wenn mir da jemand oder gerne auch mehrere weiterhelfen könnten
Vielen Dank schonmal
Lg
ElementZ
ich bin gerade dabei Javascript etwas intensiver zu lernen und stelle mir dabei selbst Aufgaben, bei denen es nur darum geht, die richtige Denkweise dafür zu trainieren.
Ich möchte ein Script basteln, dass egal welche Seite man hat und wie lang sie ist, automatisch erkennt, wohin gescrollt ist und dann "smooth", zumindest so halbwegs (besser als ein sprung), nach oben scrollt.
Dafür habe ich ein eigenes Script gebastelt:
HTML:
<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Unbenanntes Dokument</title>
<script type="text/javascript">
for(i = 0; i <= 100; i++) {
document.write("ABC<br/>");
}
var wert = null;
var ergebnis = null;
function check() {
wert = window.pageYOffset;
ergebnis = wert/100;
if(window.pageYOffset > 10) {
var abc = window.setInterval("hochfahren()", 1);
} else {
window.scrollTo(0, 0);
}
}
function hochfahren() {
if(window.pageYOffset <= 10) {
window.clearInterval(abc);
} else {
var b = "-" + ergebnis;
window.scrollBy(0, b);
}
}
</script>
</head>
<body>
<a href="javascript:check();">Hoch</a>
</body>
</html>
Mein Problem dabei ist, dass, wenn fertig nach oben gescrollt ist, das script irgendwie noch immer aktiv bleibt, also sobald man herunterscrollt wieder hochgescrollt wird. Eigentlich sollte der Intervall mit clearInterval doch beendet sein, sobald der Stand des Scrollens unter 10 fällt - wird er aber nicht.
Also wie gesagt, das ist alles nur zum Trainingszweck, ich will das nicht einsetzen, aber es würde mich schon interessieren, wie man das lösen kann.
Also, ich würde mich wirklich sehr freuen, wenn mir da jemand oder gerne auch mehrere weiterhelfen könnten
Vielen Dank schonmal
Lg
ElementZ