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

Wytłumaczył by mi ktoś dany kod js dogłębnie?

Object Storage Arubacloud
0 głosów
220 wizyt
pytanie zadane 2 sierpnia 2016 w JavaScript przez james30k Bywalec (2,260 p.)
Tak jak w pytaniu, prosiłbym o naprawdę dogłębne,rzetelne wytłumaczenie.

<script>

	$(document).ready(function() {
	var NavY = $('.nav').offset().top;
	 
	var stickyNav = function(){
	var ScrollY = $(window).scrollTop();
		  
	if (ScrollY > NavY) { 
		$('.nav').addClass('sticky');
	} else {
		$('.nav').removeClass('sticky'); 
	}
	};
	 
	stickyNav();
	 
	$(window).scroll(function() {
		stickyNav();
	});
	});
	
</script>

 

1 odpowiedź

+3 głosów
odpowiedź 2 sierpnia 2016 przez ormu16 Gaduła (4,980 p.)
wybrane 2 sierpnia 2016 przez james30k
 
Najlepsza
$(document).ready(function() {

});

Ta część kodu odpowiada za to, aby krypt nie wykonywał się przed załadowaniem dokumentu, czyli wszystkich elementów twojej strony.

var NavY = $('.nav').offset().top;     
var stickyNav = function(){
var ScrollY = $(window).scrollTop();

NavY - zapisanie do zmiennej wartości na osi Y, gdzie znajduję się górny bok elementu nawigacji.

stickyNav - zapisanie funkcji do zmiennej

ScrollY ​- zapisanie do zmiennej wartości opisującej, o ile pixeli od góry zeskrollowana jest strona

if (ScrollY > NavY) { 
        $('.nav').addClass('sticky');
    } else {
        $('.nav').removeClass('sticky'); 
    }

Chodzi to o sprawdzenie, czy użytkownik zestrollował stronę tak, że górny "bok" window jest już niżej niż górny "bok" elementu nawigacji. Możesz zobaczyć to na przykładzie, scrollująć na tej stronie miroslawzelent.pl. Jeżeli tak, do nawigacji dodawana jest klasa sticky, jeżeli nie jest usuwana.

$(window).scroll(function() {
        stickyNav();
    });

Podpięcie funkcji, do eventu. Za każdym razem, gdy użytkownik zescrolluje stronę, wykona się funkcja znajdująca się w zmiennej stickyNav.

1
komentarz 2 sierpnia 2016 przez xmentor Nałogowiec (49,520 p.)
$(document).ready(function() {
 
});

Można z tego zrezygnować jeżeli skrypt znajduje się przed zamknięciem znacznika body.

Chodzi to o sprawdzenie, czy użytkownik zestrollował stronę

Te użytkowniki to trolle są :D

3
komentarz 2 sierpnia 2016 przez Comandeer Guru (601,590 p.)

nie wykonywał się przed załadowaniem dokumentu, czyli wszystkich elementów twojej strony.

Nieprawda. To czeka na wczytanie się drzewka DOM, nie wszystkich elementów strony. Bardzo łatwo to udowodnić, dodając super ciężki obrazek. $( document ).ready odpali się przed wyświetleniem tego obrazka. 

zapisanie do zmiennej wartości na osi Y, gdzie znajduję się górny bok elementu nawigacji.

Czyli, mówiąc po ludzku, odległość nawigacji od górnej krawędzi strony :P I w sumie słowo "offset" pasuje bardziej do takiej definicji.

 

Podobne pytania

–2 głosów
0 odpowiedzi 187 wizyt
0 głosów
0 odpowiedzi 166 wizyt

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,964 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...