185 71 7MB
Polish Pages 328 [329] Year 2014
Wszelkie prawa zastrzeżone. Nieautoryzowane rozpowszechnianie całości lub fragmentu niniejszej publikacji w jakiejkolwiek postaci jest zabronione. Wykonywanie kopii metodą kserograficzną, fotograficzną, a także kopiowanie książki na nośniku filmowym, magnetycznym lub innym powoduje naruszenie praw autorskich niniejszej publikacji. Wszystkie znaki występujące w tekście są zastrzeżonymi znakami firmowymi bądź towarowymi ich właścicieli. Autor oraz Wydawnictwo HELION dołożyli wszelkich starań, by zawarte w tej książce informacje były kompletne i rzetelne. Nie biorą jednak żadnej odpowiedzialności ani za ich wykorzystanie, ani za związane z tym ewentualne naruszenie praw patentowych lub autorskich. Autor oraz Wydawnictwo HELION nie ponoszą również żadnej odpowiedzialności za ewentualne szkody wynikłe z wykorzystania informacji zawartych w książce. Redaktor prowadzący: Michał Mrowiec Projekt okładki: Studio Gravite / Olsztyn Obarek, Pokoński, Pazdrijowski, Zaprucki Fotografia na okładce została wykorzystana za zgodą Shutterstock.com Wydawnictwo HELION ul. Kościuszki 1c, 44-100 GLIWICE tel. 32 231 22 19, 32 230 98 63 e-mail: [email protected] WWW: http://helion.pl (księgarnia internetowa, katalog książek) Drogi Czytelniku! Jeżeli chcesz ocenić tę książkę, zajrzyj pod adres http://helion.pl/user/opinie/jjq131_ebook Możesz tam wpisać swoje uwagi, spostrzeżenia, recenzję. Kody źródłowe wybranych przykładów dostępne są pod adresem: ftp://ftp.helion.pl/przyklady/jjq131.zip ISBN: 978-83-283-0867-1 Copyright © Helion 2015
Poleć książkę na Facebook.com Kup w wersji papierowej Oceń książkę
Księgarnia internetowa Lubię to! » Nasza społeczność
Spis treści Wstęp . ............................................................................................ 7 Rozdział 1. Podstawy . ..................................................................................... 17 Gdy przeglądarka nie obsługuje JavaScript ..................................................................... 17 Aby autor nie zapomniał, co miał na myśli ..................................................................... 20
Rozdział 2. Pisanie na stronie i działania na zmiennych . ................................... 23 Jak umieścić tekst na stronie? . ......................................................................................... 23 Jak manipulować tekstem wyświetlanym na stronie? . .................................................... 27 Operatory . ........................................................................................................................ 30 Operatory arytmetyczne . ........................................................................................... 30 Operatory przypisania . .............................................................................................. 35 Operatory porównania . .............................................................................................. 41 Operatory logiczne . ................................................................................................... 44
Rozdział 3. Funkcje i obiekty . ......................................................................... 47 Jak zdefiniować funkcję? . ................................................................................................ 47 Funkcja zwracająca wartość . ........................................................................................... 50 Zasięg zmiennych . ........................................................................................................... 51 Funkcje predefiniowane JavaScript ................................................................................. 57 Obiekty ............................................................................................................................. 61
Rozdział 4. Instrukcje warunkowe i pętle . ........................................................ 71 Instrukcja if . ..................................................................................................................... 71 Instrukcja if... else . ...........................................................................................................76 Instrukcja switch . ............................................................................................................. 78 Operator warunkowy . ...................................................................................................... 80 Pętla while . .......................................................................................................................81 Pętla do-while . ................................................................................................................. 86 Pętla for ............................................................................................................................ 90
Rozdział 5. Tablica . ........................................................................................ 93 Rozdział 6. Obliczenia . .................................................................................. 111 Obiekt Boolean . ............................................................................................................. 111 Obiekt Date . ................................................................................................................... 115 Metody . ................................................................................................................... 117 Obiekt Math . .................................................................................................................. 120
4
JavaScript i jQuery. 131 praktycznych skryptów
Rozdział 7. Liczby i łańcuchy . ........................................................................ 123 Obiekt Number . ............................................................................................................. 123
Rozdział 8. Teksty . ....................................................................................... 139 Właściwości i metody . ................................................................................................... 142
Rozdział 9. Zdarzenia . ................................................................................... 153 Rozdział 10. JavaQuery . .................................................................................. 169 Składnia . ........................................................................................................................ 169 Dobra praktyka . ............................................................................................................. 170 Selektory jQuery . ........................................................................................................... 170 Akapit . ..................................................................................................................... 170 Identyfikator . ........................................................................................................... 172 Gwiazdka . ............................................................................................................... 175 Element bieżący . ..................................................................................................... 177 Dwa selektory . ......................................................................................................... 179 Pierwsza pozycja listy . ............................................................................................ 180 Selektor href . ........................................................................................................... 184 Nagłówki . ................................................................................................................ 186 Ciąg znaków . ........................................................................................................... 187 Hasło . ...................................................................................................................... 188 Przycisk radiowy . .................................................................................................... 190 Pole wyboru . ........................................................................................................... 191 Przycisk wysyłania . ................................................................................................. 192 Obrazek . .................................................................................................................. 194 Plik ........................................................................................................................... 195 Elementy możliwe do zmiany ................................................................................. 197 Elementy zablokowane . ........................................................................................... 199 Pozycja wstępnie wybrana na liście rozwijanej . ..................................................... 200 Wstępnie zaznaczone pole wyboru .......................................................................... 201
Rozdział 11. Efekty . ....................................................................................... 205 Zdarzenia . ...................................................................................................................... 205 Składnia dla metod zdarzeń jQuery ............................................................................... 205 Załadowanie dokumentu . ........................................................................................ 206 Kliknięcie . ............................................................................................................... 207 Podwójne kliknięcie . ............................................................................................... 209 Naprowadzenie wskaźnika myszy na element HTML . .......................................... 211 Usunięcie wskaźnika myszy z elementu HTML . ................................................... 213 Wciśnięcie klawisza myszy ..................................................................................... 214 Zwolnienie klawisza myszy .................................................................................... 216 Naprowadzenie i zwolnienie wskaźnika myszy . .................................................... 218 Umieszczenie wskaźnika myszy w polu . ................................................................ 220 Reakcja na wiele zdarzeń . ....................................................................................... 222 Zmiana tekstu . ......................................................................................................... 224 Klonowanie akapitów . ............................................................................................. 226 Identyfikacja elementu docelowego zdarzenia . ...................................................... 229 Dane przekazywane do metody obsługi zdarzeń . ................................................... 230
Rozdział 12. Manipulacja znacznikami HTML . .................................................. 233 Tekst ............................................................................................................................... 233 HTML ............................................................................................................................. 235 Wartości pola formularza . ............................................................................................. 237 Odczytywanie atrybutów . .............................................................................................. 239
Spis treści
5 Zmiana atrybutów . ......................................................................................................... 240 Dodawanie nowego elementu HTML za istniejącym elementem . ................................ 242 Dodawanie nowego elementu HTML przed istniejącym elementem ........................... 244 Dodawanie nowego elementu HTML we wskazanym miejscu . ................................... 246 Usuwanie elementów . .................................................................................................... 250 Usuwanie elementów podrzędnych ............................................................................... 252 Filtrowanie elementów do ukrycia ................................................................................ 254 Zmiana tła wyróżnionych elementów ............................................................................ 257 Dodanie klasy do arkusza CSS . ..................................................................................... 259 Usunięcie klasy z arkusza CSS . ..................................................................................... 263 Przełączenie klasy z arkusza CSS .................................................................................. 265
Rozdział 13. Witalizacja strony . ...................................................................... 269 Zmiana wymiarów obiektu . ........................................................................................... 269 Zanikanie i pojawianie się elementów strony . .............................................................. 273 Przesuwanie elementów strony ...................................................................................... 279 Animacje . ...................................................................................................................... 282 Zakończenie operacji . .................................................................................................... 297 Łańcuchy poleceń . ......................................................................................................... 300 Zmiana parametrów w pętli . .......................................................................................... 302 Przesuwanie elementów po arkuszu .............................................................................. 305 Przekierowywanie na wybrany adres URL po upływie określonego czasu .................. 308 Wcięcie tekstu . .............................................................................................................. 310 Odstęp między liniami . .................................................................................................. 312 Rozmiar czcionki . .......................................................................................................... 313 Marginesy . ..................................................................................................................... 317
Skorowidz . .................................................................................. 321
6
JavaScript i jQuery. 131 praktycznych skryptów
Wstęp Do tworzenia najprostszych stron internetowych wystarczy język HTML (ang. HyperText Markup Language — hipertekstowy język znaczników). Pozwala on na budowanie witryn statycznych. Aby stronę uatrakcyjnić, zwiększyć jej funkcjonalność, można dodatkowo posłużyć się jednym z języków skryptowych. Przykładem jest JavaScript.
JavaScript JavaScript, zwany również JS, to skryptowy język programowania stworzony przez firmę Netscape. Najczęściej jest wykorzystywany na stronach internetowych. Jest on obsługiwany przez większość współczesnych przeglądarek WWW. Pozwala na umieszczanie w kodzie HTML lub XHTML skryptów. Skrypty umożliwiają uzyskanie interaktywności, np. przez: reagowanie na zdarzenia, sprawdzanie poprawności formularzy, budowanie elementów nawigacyjnych, tworzenie ciasteczek, manipulowanie oknami przeglądarki, wyświetlanie prostych okien dialogowych, pobieranie informacji o przeglądarce, zarządzanie wtyczkami przeglądarki, zarządzanie arkuszami stylów CSS.
Przystępując do użytkowania JavaScript, należy zdawać sobie sprawę z jego wad i zalet.
8
JavaScript i jQuery. 131 praktycznych skryptów
Zalety JavaScript jest językiem skryptowym, czyli interpretowanym. Przed wykonaniem napisanego w nim programu nie musi być kompilowany do kodu maszynowego. Wystarczy przeglądarka internetowa obsługująca JavaScript. Język jest stosunkowo łatwy do opanowania. Można się go uczyć w trakcie pisania programów — tak jak możesz robić to, korzystając z książki. Napisany w nim program wykonywany jest na komputerze użytkownika. Pozwala to na odciążenie serwerów. Dzięki JavaScript można np. sprawdzić poprawność danych wprowadzanych do formularza na komputerze klienta. Jeżeli popełniony zostanie błąd, sygnalizowany jest przed wysłaniem danych do serwera. Pozwala to zaoszczędzić czas, który byłby inaczej poświęcony na wysłanie danych na serwer, weryfikację ich, wygenerowanie strony z opisem błędu i odesłanie jej z powrotem na komputer klienta. JavaScript jest nieustannie rozwijany, co pozwala się spodziewać, że nie pójdzie szybko w zapomnienie.
Wady Kłopotliwą wadą JavaScript są różnice w interpretacji kodu w różnych przeglądarkach. Oznacza to, że identyczne polecenie w różnych przeglądarkach może dać różny efekt końcowy. Aby w różnych przeglądarkach uzyskać identyczny efekt, należy używać różnych poleceń. Spowodowane jest to walką między producentami przeglądarek. Każdy stara się przeforsować swoje koncepcje i narzucić je pozostałym producentom i użytkownikom. W rezultacie nawet kod napisany zgodnie z zaleceniami W3C nie musi dawać identycznego efektu w różnych przeglądarkach.
Framework W JavaScript wszystkie elementy musimy napisać sami. Daje to wiele satysfakcji, ale pochłania mnóstwo czasu. Wiele komponentów jest wspólnych dla różnych stron WWW. Zamiast pisać je za każdym razem od początku, można je napisać raz i korzystać z nich zawsze, gdy tylko zajdzie potrzeba. Tak ułatwiają sobie pracę programiści. Piszą fragmenty kodu, których używają wielokrotnie. Ze sprawdzonych podprogramów budują większe programy. Kolejnym krokiem na drodze do ułatwienia pracy nad interaktywnymi stronami WWW jest stworzenie i publiczne udostępnienie biblioteki zawierającej przetestowane elementy kodu. Takie narzędzie nosi nazwę framework. Jest to zbiór funkcji, dzięki którym możemy osiągać efekty bez powtarzania zbędnego kodu. W programie zamiast instrukcji JavaScript używane są wywołania programów, które zawierają wiele instrukcji.
Wstęp
9
Frameworków do JavaScript jest wiele: Prototype, Dojo, Moo Tools, jQuery. Wszystkie oferują unikalne rozwiązania. Ich autorzy stawiają sobie za punkt honoru, by narzędzie było jak najszybsze i jak najbardziej przyjazne w użyciu. Nauka stosowania każdego frameworka wiąże się z opanowaniem: składni, funkcji,
jakie są niezbędne, by go używać.
jQuery Dlaczego wybierając framework do JavaScript, warto zdecydować się właśnie na jQuery? Moim zdaniem z trzech powodów: 1. Oferuje szeroką funkcjonalność (co oznacza, że stwarza możliwość
zrealizowania najbardziej zwariowanych pomysłów). 2. Ma perspektywy długiego rozwoju (dzięki temu technologia, którą
wybierzemy, nie zostanie wkrótce zarzucona i nie staniemy przez to przed problemem migracji na inną technologię lub pracowania na przestarzałej, nierozwijanej wersji). 3. Kolejne edycje nie powinny wprowadzać wielu zmian (co oznacza,
że możliwy jest upgrade wersji w już istniejących projektach bez wielkich modyfikacji). W tabeli W.1 zestawiono obszary zastosowań HTML, JavaScript i jQuery. Tabela W.1. Obszary zastosowań HTML, JavaScript i jQuery Element
Obszar zastosowań
HTML
Strony WWW statyczne
JavaScript
Strony WWW z elementami interaktywnymi
jQuery
Strony WWW z elementami interaktywnymi tworzone z gotowych, sprawdzonych elementów
HTML, JavaScript, jQuery W przykładach szkielet strony WWW zbudujemy w HTML. Do niego dodawać będziemy komponenty w JavaScript i jQuery.
10
JavaScript i jQuery. 131 praktycznych skryptów
Szablon strony HTML Kod HTML, który pozwala nas wyświetlenie statycznej strony WWW, ma postać:
HTML
Nagłówek
Treść
Treść
Treść
Treść
Treść
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse vitae vestibulum magna. Nulla facilisi. Integer et nisl vitae purus pellentesque tempor non nec ligula. Integer vitae mauris sollicitudin, congue velit in, vehicula nunc. Donec at ipsum dolor. Donec faucibus justo elit, a pulvinar lorem dapibus id. Nam congue metus nunc, a convallis erat semper ut. Suspendisse ac libero enim. In interdum metus accumsan leo dapibus, eget feugiat lacus convallis. Nam feugiat quam vel dui euismod, quis luctus risus hendrerit. Donec volutpat pharetra sapien ac egestas. Nullam arcu purus, dictum id arcu non, efficitur maximus mi. Curabitur pellentesque magna justo, quis congue turpis vestibulum non. Aenean non tincidunt dui. Nam porttitor leo non sollicitudin aliquam. Sed vulputate commodo dignissim.
Interlinia + Interlinia -Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Integer et nisl vitae purus pellentesque tempor non nec ligula. Integer vitae mauris sollicitudin, congue velit in, vehicula nunc.
i
zostały zwiększone dwukrotnie