• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Przejście do strony + automatyczny scroll

VPS Starter Arubacloud
0 głosów
1,376 wizyt
pytanie zadane 28 lipca 2016 w HTML i CSS przez thedzusi Nowicjusz (190 p.)
Cześć,

do swojej strony dodałam skrypt przewijania do różnych nagłówków po kliknięciu w zadany odnośnik umieszczony w nawigacji (tak jak w odcinku HTML #4).

Od paru dni borykam się z problemem:

Po przejściu do nowej podstrony, na której widnieje ta sama nawigacja co na stronie głównej chciałabym uzyskać efekt przekierowania do strony głównej (z tym nie mam problemu) oraz automatycznego scrolla do odpowiedniej sekcji.

Mam nadzieję, że będzie to w miarę zrozumiałe, jestem mocno początkująca.Z góry dziękuję za pomoc lub podpowiedź.

1 odpowiedź

+1 głos
odpowiedź 28 lipca 2016 przez kubaapk Nałogowiec (44,270 p.)
Poprawnie zapisz linki.

Jeśli na stronie 1 masz sekcje #omnie i scrolujesz do niej po kliknięciu to adres wygląda tak www.strona.com/#omnie czy tam index.html#omnie.

To spróbuj na tej drugiej stronie, w nawigacji zachować taką samą strukturę linków. Tj. z hashami, np.

<a href="www.strona.pl/#omnie">O mnie</a>,

czy tam <a href="index.html#omnie">O mnie</a>
komentarz 28 lipca 2016 przez thedzusi Nowicjusz (190 p.)

Moja funkcja wygląda w ten sposób:

jQuery(function($)
		{
	//		zresetuj scrolla
		$.scrollTo(0);
		$('#link2').click(function() { $.scrollTo($('#omnie'), 500); });
		$('#link3').click(function() { $.scrollTo($('#kontakt'), 500); });
	
		}	);

Próbowałam rozwiązać mój problem w sposób podany w odpowiedzi, aczkolwiek nie działa.

Funkcja wyszukuje elementy wyłącznie po nadanym id, może mogłabym to jakoś zmodyfikować, aby wyszukiwało właśnie po np. "index.html/#omnie"?

komentarz 28 lipca 2016 przez kubaapk Nałogowiec (44,270 p.)
$(document).on('click', 'a', function(event){
    event.preventDefault();

    $('html, body').animate({
        scrollTop: $( $.attr(this, 'href') ).offset().top
    }, 500);
});

 

Zamiast podpinać event do każdego linku z osobna użyj tego kodu.

I teraz jak zrobisz link z hashem. Np. <a href="#omnie">o mnie</a>

To będzie Ci skrolować do sekcji z id "omnie".

 

Sprawdź ten sposób i daj znać czy działa.

komentarz 28 lipca 2016 przez thedzusi Nowicjusz (190 p.)
Wielkie dzięki za funkcję, faktycznie działa sprawnie i bez zbędnych podpięć.

Jedynym mankamentem jest fakt, że nie działają mi w tym momencie żadne linki zewnętrzne na stronie, tym samym przejście np. do podstrony.
komentarz 28 lipca 2016 przez kubaapk Nałogowiec (44,270 p.)
Konsola coś zwraca? Kiedy klikasz w normalny link.

http://jsfiddle.net/9SDLw/6885/

Tutaj działają zewnętrzne linki, więc coś musi być u Ciebie nie tak.
komentarz 28 lipca 2016 przez thedzusi Nowicjusz (190 p.)
"skrypt.js:55 Uncaught TypeError: Cannot read property 'top' of undefined"

to odnośnie tej linijki kodu "  scrollTop: $( $.attr(this, 'href') ).offset().top", tylko to się pojawia w konsoli za każdym razem po kliknięciu w link..

ale generalnie skrypt działa.

Podobne pytania

0 głosów
2 odpowiedzi 849 wizyt
pytanie zadane 21 kwietnia 2018 w HTML i CSS przez Vinchit Obywatel (1,040 p.)
0 głosów
1 odpowiedź 353 wizyt
pytanie zadane 3 lutego 2016 w HTML i CSS przez xSvilen Mądrala (5,740 p.)
0 głosów
1 odpowiedź 203 wizyt
pytanie zadane 24 lipca 2020 w JavaScript przez Bakkit Dyskutant (7,600 p.)

93,031 zapytań

141,995 odpowiedzi

321,300 komentarzy

62,379 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 2

Można już zamawiać tom 2 książki "Wprowadzenie do bezpieczeństwa IT" - będzie to około 650 stron wiedzy o ITsec (17 rozdziałów, 14 autorów, kolorowy druk).

Planowana premiera: 30.09.2024, zaś planowana wysyłka nastąpi w drugim tygodniu października 2024.

Warto preorderować, tym bardziej, iż mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy dodatkowe 15% zniżki! Dziękujemy zaprzyjaźnionej ekipie Sekuraka za kod dla naszej Społeczności!

...