Blog webdeveloperski Patryk yarpo Jar

jQuery – szybki start

Autor wiadomości Kwiecień 3, 2011

jQuery jest jedną z najpopularniejszych (i moim skromnym zdaniem) najlepszych bibliotek JS. Jej dodatkową zaletą jest to, że jest darmowa. Chciałbym dzisiaj pokazać jak banalnie łatwo jest zacząć jej używać. Zapraszam do lektury.

Załączenie biblioteki:

Istnieje kilka sposobów:

  1. Pobranie kodu ze strony projektu jQuery a następnie załączenie go jako osobnego pliku.
  2. Załączenie kodu bezpośrednio ze strony autorów.

ad 1: jeśli padnie serwer, nadal masz działającą bibliotekę, ale zajmuje ona miejsce u Ciebie na serwerze,, musisz ją pobrać itp. itd.

ad 2: dla przykładu szybkiego zastosowania będę używał tej metody - nie musisz się przejmować żadnymi ścieżkami. jednak we własnych projektach prawie zawsze używam metody 1.

<html>
<head>
    <title>jQuery w akcji!</title>
    <script src="http://code.jquery.com/jquery-1.4.1.min.js" type="text/javascript"></script>
    <script type="text/javascript">
    $(document).ready(function() {
        alert('Witaj świecie');
    });
    </script>
</head><body></body></html>

W wyniku uzyskamy alert "Witaj świecie". Właściwie nic wielkiego... Po to załączać wielką bibliotekę (30KB to w sumie nie taka wielka), aby wyświetlać alert... Spokojnie, można DUŻO więcej.

Chwytanie węzłów

Każdy znacznik HTML to węzeł w modelu DOM. Można zatem go złapać i wykonać na nim jakieś czynności.

$('wezel').metoda(function() { dzialanie });

Na przykład:

$('body').click(function() { $(this).css({ 'background' : 'red'}) });

W powyższym przykładzie, po kliknięciu na dowolny kawałek strony tło zmieni kolor na czerwony. Zmienna this wewnątrz funkcji anonimowej przekazywanej do metody zawsze wskazuje na węzeł aktualnie przetwarzany (czyli w powyższym przypadku na <body> - ciało strony).

Tu trochę inny przykład:

&lt;html&gt;
&lt;head&gt;
    &lt;title&gt;jQuery w akcji!&lt;/title&gt;
    &lt;script src="http://code.jquery.com/jquery-1.4.1.min.js" type="text/javascript"&gt;&lt;/script&gt;
    &lt;script type="text/javascript"&gt;
    $(document).ready(function() {
        $('p').click(function() {
            alert("Kliknąłeś mnie!"); // dla dowolnego znacznika p na stronie
        });
    });
&lt;/script&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;p&gt;To jest napis&lt;/p&gt;
    &lt;p class="moj"&gt;To jest inny napis, ale też będzie działać&lt;/p&gt;
    &lt;p id="twoj"&gt;A tu jeszcze co innego&lt;/p&gt;
&lt;/body&gt;
&lt;/html&gt;

Powyższy przykład sprawi, że klikając na dowolny napis wyświetli się alert.

Same alert?!

Ktoś mógłby stwierdzić, ze jQuery to tylko nakładka pozwalająca jedynie używać alertów. Nic bardziej mylnego. Używałem alertów bo są dosyć jednoznaczne - trudno je przegapić.

Można jednak osiągnąć dużo ciekawsze efekty. Oto przykład.

&lt;html&gt;
&lt;head&gt;
    &lt;title&gt;jQuery w akcji!&lt;/title&gt;
    &lt;script src="http://code.jquery.com/jquery-1.4.1.min.js" type="text/javascript"&gt;&lt;/script&gt;
    &lt;script type="text/javascript"&gt;
    function show(id) {
        $('div[id^="content"]').fadeOut(); // 1
            $('#' + id).fadeIn(); // 2
    }
    $(document).ready(function() {
        $('#show2').click(function() { // 3
            show('content2');
        });
    });
&lt;/script&gt;
&lt;style type="text/css"&gt; #content1, #content2 { display:none; } &lt;/style&gt;
&lt;/head&gt;
&lt;body&gt;
    &lt;ul&gt;
        &lt;li&gt;&lt;a href="javascript:show('content1')"&gt;Pokaż 1&lt;/a&gt;&lt;/li&gt;&lt;!-- 4 --&gt;
        &lt;li&gt;&lt;a href="#" id="show2"&gt;Pokaż 2&lt;/a&gt;&lt;/li&gt;               &lt;!-- 5 --&gt;
        &lt;li&gt;&lt;a href="#" onclick="show('content3')"&gt;Pokaż 3&lt;/a&gt;&lt;/li&gt;&lt;!-- 6 --&gt;
    &lt;/ul&gt;
    &lt;div id="content1"&gt;To jest treść 1&lt;/div&gt;
    &lt;div id="content2"&gt;To jest treść 2&lt;/div&gt;
    &lt;div id="content3"&gt;Sialalaal&lt;/div&gt;
&lt;/body&gt;&lt;/html&gt;

Z ciekawych rzeczy jakie tu zostały zastosowane:
meteda `fadeOut' - powoduje powolne ukrycie wszystkich elementów wskazanych w konstruktorze obiektu.

  1. Tu w konstruktorze użyłem wyrażeń regularny. Oznacz to "wszystkie div, które posiadają atrybut id rozpoczynających się na 'content'". Czyli np.: "content", "content1", "content_sialalala".
  2. `fadeOut' - przeciwieństwo `fadeIn'. api.jquery.com/fadeIn/
  3. Dla znacznika (węzła DOM) o id = "show2" (zauważ, że węzły tu łapie się identycznie jak w CSS) przypisz na zdarzenie `click' akcję.
  4. Pseudoadresy
  5. Tu zostawimy wolny atrybut `href'. Przypiszemy działanie w JS (patrz pkt 3)
  6. Przypisanie akcji na zdarzenie `click'. Działanie identyczne jak pkt 3, z tym, że zrobione w natywnym JS.

Jeśli byłbyś zainteresowany jQuery, warto zajrzeć tu:

Ja może zauważyłeś używałem tu wielokrotnie funkcji anonimowych.

Warto przeczytać

Powodzenia 🙂 !

Komentarze (0) Trackbacks (1)

Leave a comment