Języki interpretowane
|
|
- Kajetan Rutkowski
- 9 lat temu
- Przeglądów:
Transkrypt
1 Języki interpretowane dr inż. Andrzej Grosser Rok akademicki 2013/14 dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 1 / 182
2 Plan wykładów I 1 Wprowadzenie do języków skryptowych 2 JavaScript - składnia, bibliotek standardowa 3 JavaScript - zastosowania po stronie przeglądarki 4 Biblioteka JQuery dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 2 / 182
3 Języki skryptowe Język skryptowy jest językiem programowania, który umożliwia uruchamianie w specjalnym środowisku programów (skryptów). Z reguły te programy są interpretowane a nie kompilowane. Przeznaczeniem tych języków jest automatyzacja powtarzalnych zadań, są również stosowane jako języki osadzone w większych aplikacjach. Ze względu na swoje właściwości są czasem nazywane językami bardzo wysokiego poziomu lub nawet językami specyfikacji. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 3 / 182
4 PHP Język powstał w połowie lat 90 dwudziestego wieku. Twórcą pierwszej wersji języka jest Rasmus Lerdorf. Jest językiem wieloplatformowym - implementacje można znaleźć dla różnych systemów (między innymi Windows, Linux, BSD). Wspiera programowanie obiektowe i strukturalne. Jest językiem dynamicznym z słabą kontrolą typów. Jego głównym zastosowaniem jest generowanie stron internetowych na przykład na podstawie danych wprowadzonych w formularz przez użytkownika. Jego implementacje są najczęściej interpreterami (uruchamianymi po stronie serwera). Najnowsza wersja języka to 5.5 (5.5.4). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 4 / 182
5 Python Powstał we wczesnych latach 90 dwudziestego wieku jako następca języka ABC. Twórcą języka jest Guido van Rossum. Jest językiem wspierającym kilka paradygmatów programowania - między innymi obiektowy, funkcyjny, strukturalny. Jest dynamicznym, interpretowanym językiem programowania. Filozofia programowania kładzie nacisk na prostotę i czytelność programów (The Zen of Python). Zarządzanie pamięcią jest realizowane z wykorzystaniem automatycznego odśmiecania. Obecnie są w użyciu dwie linie języka: Python 2.x (najnowsza wersja 2.7.5) i Python 3.x (najnowsza wersja 3.3.2). Najważniejsze implementacje to CPython, IronPython, Jython i PyPy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 5 / 182
6 Ruby Został stworzony w 1995 roku przez Japończyka Yukihiro Matsumoto. Popularność poza Japonią zdobył dzięki frameworkowi Ruby on Rails. Implementacje są interpreterami. Jest dynamicznym językiem obiektowym (wszystko jest obiektem) z wsparciem dla programowania funkcyjnego i strukturalnego. Jest językiem bardzo elastycznym - przede wszystkim dzięki możliwość podmiany zachowania obiektów w czasie uruchomienia programu - nawet typów wbudowanych. Posiada automatyczne odśmiecanie pamięci. Najnowszą wersją języka jest 2.0 (w przygotowaniu 2.1). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 6 / 182
7 Tcl Tcl (Tool Command Language) został stworzony przez Johna Outershouta. Jest interpretowanym językiem dynamicznym. Jest używany jako język rozszerzeń, skryptów powłoki itp. Jest ściśle zintegrowany z biblioteką graficzną Tk (Tcl/Tk). Umożliwia przenoszenie oprogramowania na różne platformy (Unix, Linux, Windows). Najnowsza wersja pochodzi z 2013 roku (8.6.1). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 7 / 182
8 Perl Perl powstał w 1987 roku, został stworzony przez Larry ego Walla. Perl jest wysokopoziomowym językiem interpretowanym. Jest używany przede wszystkim do przetwarzania plików tekstowych, wykonywania operacja na powłoce, a także jako język rozszerzeń. Jest wieloplatformowy. Najnowsza wersja pochodzi z stycznia 2014 roku. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 8 / 182
9 Podstawowa trójka internetowa Podstawą każdej większej strony internetowej są: HTML - specyfikacja zawartości strony CSS - specyfikacja wyglądu strony JavaScript - specyfikacja zachowania strony. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 9 / 182
10 JavaScript - ogólna charakterystyka JavaScript - wysokopoziomowy, dynamiczny, nietypowany interpretowany język programowania. Zawiera wsparcie dla obiektowego i funkcyjnego stylu programowania. Jest wspierany przez najważniejsze przeglądarki. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 10 / 182
11 Składowe JavaScript Rdzeń - ECMAScript - opisuje składnię i semantykę języka (nie są opisywane szczegóły związane z przeglądarką). DOM (Document Object Model) - API dla XML, które zostało rozszerzone do użycia z HTML. DOM opisuje stronę jako hierarchię węzłów. BOM (Browser Object Model) - API umożliwiające dostęp i zmiany okna przeglądarki (przesuwanie, otwieranie, zamykanie). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 11 / 182
12 Historia JavaScript Język został stworzony przez Brendona Eicha w firmie Netscape w Oryginalną nazwą była Mocha, potem LiveScript a na końcu pu uzyskaniu pozwolenia od firmy Sun JavaScript. Język jest ustandaryzowany przez ECMA (1996) - w standardzie nosi nazwę ECMAScript (innym językiem, który spełnia ten standard z rozszerzeniami jest ActionScript). Najnowszą edycją standardu ECMAScript jest wersja 5.1 (czerwiec 2011). Następną wersją będzie wersja 6(Harmony lub ES.next). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 12 / 182
13 Narzędzia wspierające budowę oprogramowania JSFiddle - aplikacja online pozwalająca na uruchamianie i testowanie kodu (darmowe). Firebug - dodatek do Firefoxa - pozwala na testowanie i debugowanie kodu (darmowe). Aptana - oparte o Eclipse środowisko programowania aplikacji web (darmowe). WebStorm - środowisko programowania aplikacji web (niestety komercyjne). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 13 / 182
14 Osadzenie kodu w przeglądarce W dokumencie HTML można umieścić skrypt JavaScript pomiędzy znacznikami <script> i </script>. < s c r i p t language="javascript"> //... // Treść skrytpu JavaScript //... </ s c r i p t > Można się również odwoływać do zewnętrznych plików z kodem JavaScript: < s c r i p t s r c="p.js" type="text/javascript" l anguage="javascript"></s c r i p t > dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 14 / 182
15 Podstawowe elementy I Programy JavaScript zapisuje się używając Unicode. Jest rozróżniana wielkość liter - np. A i a są różnymi identyfikatorami. Białe znaki (spacja, tabulacja itp.) są z reguły pomijane w trakcie analizy leksykalnej. Jedynym wyjątkiem są znaki nowego wiersza, które mogą być separatorami instrukcji, gdy można jednoznacznie określić, gdzie instrukcja się kończy. Opcjonalnymi separatorami instrukcji są znaki średnika. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 15 / 182
16 Komentarze Komentarze są takie jak w Javie i C++. Jednolinijkowe są zapisywane pomiędzy znakami // i znakiem nowego wiersza. Wielolinijkowe komentarze są zapisywane pomiędzy znakami /* i */. Na przykład: // Komentarz jednlinijkowy var x = 1 0 ; /* Komentarz zajmuj ący wiele linii*/ dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 16 / 182
17 Podstawowe typy I Liczby E2 Wartości logiczne true f a l s e Łańcuchy znaków "Stała łań cuchowa" Inna stała łań cuchowa dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 17 / 182
18 Podstawowe typy II Data i czas var d1 = new Date (2014, 1, 13) ; var d2 = new Date (2014, 1, 14, 10, 0, 0) ; Wyrażenia regularne - składnia Perla var s t r = "Liczby: 1, 2, 3" ; var wzorzec = /d+/g ; wzorzec. t e s t ( s t r ) ; s t r. s e a r c h ( wzorzec ) ; s t r. match ( wzorzec ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 18 / 182
19 Obiekty I Obiekty są nieuporządkowaną kolekcją właściwości, które zawierają wartości typów podstawowych, innych obiektów lub funkcji. Każda z właściwości obiektu posiada swoją własną nazwę. Nazwy właściwości mogą być łańcuchami znaków zawierającymi spacje. Obiekty JavaScript (podobnie jak w Pythonie) są dynamiczne - można dodawać i usuwać z nich właściwości. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 19 / 182
20 Obiekty II var s t u d e n t = { nazwisko : "Kosmyk", wiek : 22, " numer indeksu" : } daneosobowe : function ( ) { return t h i s. nazwisko + t h i s. wiek + t h i s [ " numer indeksu" ] ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 20 / 182
21 Tablice I Tablica jest uporządkowaną kolekcją wartości. Tablice JavaScript są specjalnym rodzajem obiektów, nazwami właściwości są kolejne liczby całkowite (licząc od zera). Elementy tablicy w JavaScript mogą mieć dowolny typ (nawet różny). Dostęp do elementów jest realizowany za pomocą operatora indeksowania. Liczbę elementów tablicy można określić za pomocą własności length. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 21 / 182
22 Tablice II var tab1 = [ 1, 2, 3, 4 ] ; var tab2 = [ 1, true, "x" ] ; var tab3 = new Array (20) ; f o r ( var i = 0 ; i < tab. l e n g t h ; ++i ) tab1 [ i ] = 1 2 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 22 / 182
23 Wartości null i undefined Słowo null reprezentuje wartość specjalną używaną do zaznaczenia braku konkretnej wartości (jak null w Javie). Słowo undefined również oznacza brak wartości. jest wartością niezainicjowanej zmiennej, jest zwracane w sytuacji, gdy nie zostanie odszukana wartość odnosząca w tablicy, jest zwracane przez funkcję, która nie ma określonego typu wartości zwracanych. Wartość undefined jest reprezentowana przez własność obiektu globalnego. Poza opisaną różnicą oba słowa mogą być używane zamiennie. n u l l == undefined ; //true n u l l === undefined ; //false dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 23 / 182
24 Obiekty globalne Obiekt globalny jest obiektem dostarczającym własności dostępne dla całego programu JavaScript. W czasie startu interpretera są tworzone własności obiektu globalnego: globalne właściwości takie jak undefined, Infinity, NaN. funkcje globalne - np. isnan(), parseint(). konstruktory np. Date(), RegExp(), String() itd. obiekty globalne jak Math i JSON. W kodzie najwyższego poziomu, który nie jest częścią funkcji, można użyć słowa kluczowego this do odwołania do obiektu globalnego. Dla aplikacji klienckich obiekt Window dostarcza obiektu globalnego object dla kodu JavaScript zawartego w oknie przeglądarki. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 24 / 182
25 Zmienne Nazwa identyfikatora zmiennej lub funkcji musi się zaczynać od liter (w tym Unicode), podkreślenia lub znaku dolara, po którym może nastąpić sekwencja liter, cyfr, znaków podkreślenia lub dolara. Słowa kluczowe: break, case, catch, continue, default, debugger, delete, do, else, false, finally for, function, if, in, instanceof, new, null, return, switch, this, throw, true, try, typeof var, void, while. Słowa zarezerwowane: class, const, enum, export, extends, import, super. W trybie strict są również zarezerwowane: implements, interface, let, package, private, protected, public, static, yield. Niedozwolone jest używanie identyfikatorów: arguments i eval. ECMAScript 3 rezerwuje wszystkie słowa kluczowe Javy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 25 / 182
26 Deklaracje zmiennych Zmienne przed użyciem powinny być zadeklarowane. Do deklaracji zmiennej używa się słowa kluczowego var, deklaracja może być połączona z inicjowaniem zmiennej. var x ; var i, j ; var y = "kot" ; Zmienne mogą przechowywać wartości różnych typów (nie jest do nich przypisany określony typ po definicji). var x = 1. 0 ; x = "pies" ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 26 / 182
27 Zasięg widoczności zmiennych I Zasięg widoczności zmiennej zależy od miejsca definicji: obiekty globalne są widoczne w całym programie obiekty zdefiniowane w funkcjach (lokalne) są widoczne jedynie w ciele funkcji, w której zostały umieszczone. Zmienne są widoczne nawet przed swoją deklaracją, są przytwierdzone do początku funkcji (ang. hoisting). Funkcje mogą być zagnieżdżone - każda funkcja ma własny zasięg lokalny. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 27 / 182
28 Zasięg widoczności zmiennych II JavaScript nie posiada zasięgu blokowego (w przeciwieństwie do C++) var k = 0 ; i f ( i == 10) { var m = 154; f o r ( var l = 0 ; l < 5 ; ++l ) { //... } // l nadal widoczne } // m zdefiniowane, ale nie musi być zainicjowane. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 28 / 182
29 Wyrażenia i operatory I Operatory arytmetyczne: jednoargumentowe operatory +,, ++,, mnożenie, dzielenie /, dzielenie modulo % (działa także dla liczb zmiennoprzecinkowych), dodawanie + (i operator konkatenacji), odejmowanie, Operatory bitowe: bitowa koniunkcja &, bitowa alternatywa, bitowa alternatywa wyłączająca (xor) ^, bitowe zaprzeczenie ~, przesunięcie bitowe w lewo <<, przesunięcie bitowe w prawo ze znakiem >> (bity z lewej strony są wypełniane bitem znaku), przesunięcie bitowe w prawo >>> (bity z lewej strony zawsze zerowe), dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 29 / 182
30 Wyrażenia i operatory II Operatory relacyjne: równość i nierówność - operatory ==, ===,!=,!==. Operator === jest operatorem identyczności, działa jak ==, ale bardziej rygorystycznie oprócz sprawdzania wartości operandów sprawdzany jest również ich typ, nie są wykonywane żadne konwersje typów. "1" == true // true "1" === true // false 1. 0 == 1 // true 1. 0 === 1 // true - ten sam typ Number Operatory porównania - <, >, <=, >= dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 30 / 182
31 Wyrażenia i operatory III Operator in - zwraca prawdę w wtedy i tylko wtedy, gdy wartość zapisana po lewej stronie jest nazwą właściwości obiektu zapisanego po prawej stronie (przy czym wartość stojąca po lewej stronie musi być łańcuchem znaków lub dać się do tego łańcucha znaków skonwertować). var o b j = {a : 1 2}; "a" i n o b j ; //true "x" i n o b j ; //false Operator instanceof - zwraca prawdę wtedy i tylko wtedy gdy obiekt stojący po lewej stronie operatora jest instancją typu zapisanego po prawej stronie: dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 31 / 182
32 Wyrażenia i operatory IV var data = new Date (2014, 1, 1) ; data i n s t a n ceof Date ; //true data i n s t a n ceof Number ; //false data i n s t a n ceof Object ; //true dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 32 / 182
33 Wyrażenia i operatory V Operatory logiczne: koniunkcja - &&, alternatywa -, zaprzeczenie -!. Operatory przypisania - = i formy skrótowe (np. *=, +=, -= itd). x = x + 4 ; // jest równoważne x += 4 ; Operator warunkowy?: arg > 0? 1 : 1; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 33 / 182
34 Wyrażenia i operatory VI Operator typeof - operator jednoargumentowy, zwraca łańcuch znaków reprezentujący typ operandu. typeof 2 ; //"number" typeof "X" ; // "string" typeof n u l l ; //"object" typeof undefined ; //"undefined" typeof true ; //"boolean" Operator delete - powoduje usuwanie własności obiektu lub elementu tablicy. var o b j = {a : 1, b : 2 } ; delete o b j. a ; var tab = [ 3, 4, 5 ] ; delete tab [ 2 ] ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 34 / 182
35 Wyrażenia i operatory VII Operator void - jednoargumentowy, niezależnie od operandu zawsze zwraca wartość undefined - użyteczny, gdy należy pominąć przy wyświetlaniu wartości zwracane - na przykład bez wyświetlania w oknie przeglądarki. Operator przecinka - działanie takie jak w C++ - wartością zwracaną jest wartość wyrażenia z prawej strony, rzadko występuje samodzielnie - najczęściej używany w pętli for. // Wartością wyrażenia zapisanego poniżej jest 3 x = 1, y = 2, z = 3 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 35 / 182
36 Instrukcje I Instrukcja warunkowa - działanie takie jak w C++ i Javie - wartościowane wyrażenie w nawiasach okrągłych jeżeli jest prawdziwe to wykonywana jest instrukcja zapisana po wyrażeniu, jeżeli jest fraza else to jest wykonywana w sytuacji, gdy wyrażenie w nawiasach okrągłych jest wartościowane do fałszu. i f ( x > 0) x = x ; i f ( y > 0) { return y ; } e l s e { return y ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 36 / 182
37 Instrukcje II Instrukcja wyboru - składniowo podobne do instrukcji z C++ i Javy, Wyrażenia etykiet są wartościowane w czasie uruchomienia. Etykieta może być wyrażeniem dowolnego typu. switch ( d z i e n ) { case " poniedzia łek" : return 1 ; case " wtorek" return 2 ; //... d e f a u l t : return 1; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 37 / 182
38 Instrukcje III Pętla while - działanie takie jak w C++, dopóki wyrażenie zapisane w nawiasach okrągłych zwraca prawdę wykonywane jest ciało pętli: var i = 0 ; while ( i < 100) { ++i ; } Pętla do while - działanie takie jak w C++, dopóki wyrażenie zapisane w nawiasach okrągłych zwraca prawdę wykonywane jest ciało pętli, pętla wykonywana jest przynajmniej raz: var i = 0 ; do { ++i ; } while ( i < 100) dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 38 / 182
39 Instrukcje IV Pętla for - działanie takie jak w C++, Najpierw wykonywana jest część inicjalizacyjna, potem wykonywany jest test, ciało pętli jeżeli test jest wartościowany do prawdy, na końcu część związana z modyfikacją zmiennych (np. liczników). Iteracje są wykonywane aż do momentu, gdy test zwróci fałsz (lub pętla zostanie zakończona break, return). f o r ( var i = 0 ; i < 100; ++i ) { //... } Pętla for in = używana do przechodzenia po własnościach obiektu lub elementach tablicy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 39 / 182
40 Instrukcje V f o r ( var i = 0 ; i < tab. l e n g t h ; ++i ) tab [ i ] = i ; f o r ( var i i n tab ) tab [ i ] = i ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 40 / 182
41 Instrukcje VI Skoki - break, continue - działanie takie jak w Javie - możliwy zapis z etykietą do której ma przejść sterowanie po osiągnięciu tej instrukcji. e t y k i e t a : f o r ( var i = 0 ; i < 1 0 ; ++i ) { f o r ( var j = 0 ; j < 1 0 ; ++j ) { f o r ( var k = 0 ; k < 1 0 ; ++k ) i f ( tab [ k ] < 0) break e t y k i e t a ; } } Instrukcja powrotu - return. Zgłoszenie wyjątku - throw. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 41 / 182
42 Instrukcje VII Obsługa sytuacji wyjątkowych - obsługa podobna jak w Javie (ale tylko jeden blok catch) Kod, w którym może wystąpić wyjątek jest objęty blokiem try. Wyjątki są przechwytywane w bloku catch. Niezależnie od tego czy został zgłoszony jakikolwiek wyjątek wykonywany jest blok finally. t r y { // Normalny kod } catch ( e ) { // Kod obsługi wyjątku } f i n a l l y { // Kod kończący } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 42 / 182
43 Funkcje I Definicja funkcja rozpoczyna się od słowa kluczowego function, po którym znajduje się zapisany w nawiasach okrągłych zbiór jej argumentów (rozdzielanych przecinkami) i ciało funkcji. Funkcje w JavaScript nie sprawdzają, ile argumentów dostają na wejściu. Argumenty wywołania funkcji są przechowywane w zmiennej arguments. Kolejne argumenty można uzyskać korzystając z operatora indeksowania. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 43 / 182
44 Funkcje II function kwadrat ( x ) { return x x ; } function kwadrat2 { return arguments [ 0 ] arguments [ 0 ] ; } kwadrat ( ) ; kwadrat (12) ; kwadrat ( 1 0, 1 2 1, 1 2 ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 44 / 182
45 Literatura 1 D.Flanagan JavaScript: The Definitive Guide wydanie szóste, O Reilly Media N.C. Zakas Proffesional: JavaScript for Web Developers wydanie trzecie, John Wiley & Sons 2012 dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 45 / 182
46 Funkcje jako obywatele pierwszego rzędu I Funkcje są traktowane jako każda inna wartość: Można przekazywać funkcje do innych funkcji jako argumenty, Można zwracać jako wynik funkcję, Można definiować funkcje lokalne (zagnieżdżone), Można definiować funkcje anonimowe (nienazwane). Funkcje przyjmujące i zwracające funkcje to funkcje wyższego rzędu. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 46 / 182
47 Funkcje jako obywatele pierwszego rzędu II function p r z y k l a d ( fun ) { function l o k a l n a ( ) { return fun ( ) ; } return l o k a l n a ; } f u n k c j a = p r z y k l a d ( function ( ) { return 2 2}) ; f u n k c j a ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 47 / 182
48 Domknięcia I JavaScript używa zasięgu leksykalnego (statycznego). Zasięg leksykalny oznacza, że gdy funkcja jest wykonywana używa zmiennych z miejsca, w którym została zdefiniowana a nie z miejsca, w którym została wywołana. Dla implementacji zasięgu leksykalnego konieczne jest przechowywanie środowiska, w którym została zdefiniowana funkcja (zbiór zmiennych wpływających na zachowanie funkcji). Połączenie obiektu funkcji z jej zasięgiem (wystarcza zbiór wiązań zmiennych wolnych) jest nazywany domknięciem (ang. closure. Wszystkie funkcje w JavaScript są domknięciami. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 48 / 182
49 Domknięcia II function z w i e r z e ( ) { var gatunek = "orangutan" ; function wewnetrzna ( ) { a l e r t ( gatunek ) ; } return wewnetrzna ; } //... var gatunek = "goryl" ; z w i e r z = z w i e r z e ( ) ; z w i e r z ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 49 / 182
50 Domknięcia III Zmienne wolne są przekazywane przez referencję. Jeżeli funkcja zwraca inną funkcję to przy każdym wywołaniu tworzone jest inne domknięcie. Daje to możliwość utworzenia zmiennych pomocniczych. function p r z y k l a d ( ) { var l i c z b a = 0 ; var l i c z n i k = function ( ) { a l e r t (++ l i c z b a ) ; } return l i c z n i k ; } zm = p r z y k l a d ( ) ; //1 2 zm ( ) ; zm ( ) ; // 1 - inne domkni ęcie p r z y k l a d ( ) ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 50 / 182
51 Literały obiektowe Literałem obiektowym jest nazywana lista rozdzielonych przecinkami par (nazwa właściwości, wartość) umieszczona w nawiasach klamrowych. Nazwami właściwości są identyfikatory lub łańcuchy znaków. Wartością w parze są dowolne wyrażenia JavaScript. var p u s t y = { } ; var p r o s t o k a t = {a : 1. 0, b : 2. 0 } ; var a u t o r = { i m i e : "Jan", "drugie imie" : "Tadeusz", nazwisko : "Moziński", a d r e s : { m i e j s c o w o s c : "Warszawa" } } ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 51 / 182
52 Tworzenie obiektów z wykorzystaniem new Instrukcja new tworzy i inicjuje nowy obiekt. Po słowie kluczowym new musi wystąpić wywołanie funkcji - konstruktora. Dla typów wbudowanych: var o b i e k t = new Object ( ) ; var t a b l i c a = new Array ( ) ; var data = new Date ( ) ; var wr = new RegExp ( "a+" ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 52 / 182
53 Tworzenie obiektów z wykorzystaniem Object.create() ECMAScript 5 definiuje do tworzenia obiektów metodę Object.create(). Metoda ta tworzy nowy obiekt używając swojego parametru jako prototypu tego obiektu. Metoda create umożliwia przekazywanie drugiego, opcjonalnego parametru, który opisuje właściwości nowego obiektu. // obj odziedziczy właściwości a i b var o b j = Object. c r e a t e ({ a : 1, b : 2 } ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 53 / 182
54 Programowanie obiektowe Wpływ na definicję nowego typu w JavaScript mają: konstruktor - obiekt funkcji, który definiuje nazwę dla nowej klasy, właściwości dodane w konstruktorze są polami i metodami (w przypadku podstawiania funkcji do właściwości) klasy. prototyp - część obiektu, która jest dziedziczona przez wszystkie obiekty klasy, obiekt instancji - jest instancją nowego typu, właściwości przypisane do obiektu po jego utworzeniu nie są współdzielone z innymi obiektami. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 54 / 182
55 Konstruktor I W terminologii JavaScript konstruktor to funkcja, która jest używana do inicjowania nowego obiektu. Konstruktor powinien być wywoływany z użyciem słowa kluczowego new (wywołany bez new utworzy właściwość obiektu globalnego). Każda funkcja JavaScript może być użyta jako konstruktor (poza funkcjami zwracanymi przez metodę Function.bind() - ECMAScript 5). Właściwość prototype konstruktora jest używana jako prototyp nowego obiektu - wszystkie obiekty są tworzone z wykorzystaniem jednego konstruktora i mają w ten sposób jeden typ. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 55 / 182
56 Konstruktor II function Punkt ( x, y ) { t h i s. x = x ; t h i s. y = y ; t h i s. o d l = function ( ) { return Math. s q r t ( t h i s. x t h i s. x + t h i s. y t h i s. y ) ; } } // Tworzenie instancji p1 = new Punkt ( 1, 2 ) // p2 - undefined - tylko wywołanie funkcji p2 = Punkt ( 3, 4 ) dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 56 / 182
57 Prototypy I Każdy obiekt JavaScript posiada dwie części: wartość określającą jego zawartość, prototyp. Wartość obiektu jest tworzona na podstawie prototypu. Każdy literał obiektowy posiada ten sam prototyp - Object.prototype. Prototyp może być określany z wykorzystaniem konstruktorów. Dostęp do prototypu - Object.getPrototypeOf(obj) Dodatkowo dostęp do prototypu (poza IE) jest możliwy z wykorzystaniem proto. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 57 / 182
58 Prototypy II var P r o s t o k a t = function ( a, b ) { t h i s. a = a ; t h i s. b = b ; } P r o s t o k a t. p r o t o t y p e. obwod = function ( ) { return 2 t h i s. a + 2 t h i s. b ; } var p = new P r o s t o k a t ( 1 0, 2 0 ) ; p. obwod ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 58 / 182
59 Prototypy III Mechanizm tworzenia typów w oparciu o prototypy jest dynamiczny. Obiekt dziedziczy właściwości prototypu, nawet w sytuacji, gdy prototyp zostanie zmieniony po utworzeniu obiektu. Umożliwia to rozszerzanie typów poprzez dodawanie nowych metod. Przedstawiony mechanizm działa również dla typów wbudowanych - można rozszerzać liczby, łańcuchy, tablice itd. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 59 / 182
60 Prototypy IV Number. p r o t o t y p e. p r z e c i w n a = function ( ) { return t h i s ; } var x = 1; x. p r z e c i w n a ( ) ; // Usuwa białe znaki z lewej strony S t r i n g. p r o t o t y p e. l t r i m = function ( ) { return t h i s. r e p l a c e (/ˆ\ s +/, ) ; } //x - "X " var x = " X " ; x. l t r i m ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 60 / 182
61 Usuwanie właściwości I Do usuwania właściwości z obiektu służy operator delete. Operand delete musi być wyrażeniem służącym do dostępu do właściwości. Operator delete zwraca wartość prawdy, gdy usunięcie zakończyło się sukcesem lub nie spowodowało żadnego efektu. Można usuwać tylko właściwości własne obiektu. Operator delete zwraca wartość fałszu, gdy operacja usunięcia właściwości jest niemożliwa do przeprowadzenia. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 61 / 182
62 Usuwanie właściwości II o b j = {x : "A", y : 12}; //Prawda delete o b j. x ; //Prawda delete o b j. x ; //Prawda delete o b j. z ; //fałsz delete Object. p r o t o t y p e dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 62 / 182
63 Metody porównujące Operator równości JavaScript porównuje obiekty przez referencję a nie przez ich zawartość - obiekty są równe wtedy i tylko wtedy, gdy są tymi samymi obiektami. Porównywanie wartości poszczególnych składowych jest możliwe poprzez zdefiniowanie i późniejsze wykorzystanie metod. Punkt. p r o t o t y p e. e q u a l s = function ( o b j ) { i f ( o b j == n u l l ) ( o b j. c o n s t r u c t o r!== Punkt ) return f a l s e ; return t h i s. x == o b j. x && t h i s. y == o b j. y ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 63 / 182
64 Właściwości prywatne i uprzywilejowane I Publiczne właściwości są deklarowane wewnątrz metod obiektu w postaci this.nazwa. Publiczne metody są definiowane z wykorzystaniem prototypu: Klasa. p r o t o t y p e. metoda = function ( ) {... } Prywatne zmienne są deklarowane z wykorzystaniem var, mogą być osiągalne jedynie z wykorzystaniem funkcji prywatnych i uprzywilejowanych (nie każda jednak taka funkcja ma dostęp - wykorzystanie domknięcia). Prywatne funkcje są definiowane wewnątrz konstruktora typu lub za pomocą konstrukcji: var f u n k c j a = function ( ) {... } Właściwości statyczne są definiowane jako Klasa.nazwa = expr;. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 64 / 182
65 Właściwości prywatne i uprzywilejowane II function Kolo ( r, x0, y0, k o l o r ) { // Pola prywatne var x0 = x0 ; var y0 = y0 ; var r = r ; // Metoda uprzywilejowana t h i s. getr = function ( ) { return r ; } // Pole publiczne t h i s. k o l o r = k o l o r ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 65 / 182
66 Właściwości prywatne i uprzywilejowane III // Metoda publiczna // Konieczne wykorzystanie metody uprzywilejowanej // przy dostępie do zmiennych prywatnych Kolo. p r o t o t y p e. p o l e = function ( ) { return Math. PI t h i s. getr ( ) t h i s. getr ( ) ; } // Atrybut statyczny Kolo. l i c z b a = 0 k o l o = new Kolo ( 1, 2, 3, "czerwony" ) ; // Atrybut instancji k o l o.m = 4 3 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 66 / 182
67 Instrukcja with I Dostęp do atrybutów obiektów może być skracany z wykorzystaniem instrukcji wiążącej with. Zazwyczaj do dostępu do składowej używa się nazwy obiektu, operatora dostępu do składowej i składową: o b j. x = 1 2 ; o b j. y = 1 0 ; Można jednak użyc with: with ( o b j ) { x = 1 2 ; y = 1 0 ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 67 / 182
68 Instrukcja with II W praktyce with jest kłopotliwe i może prowadzić do niejednoznaczności: with ( o b j ) { a = b ; } Zapisaną powyżej instrukcję można interpretować jako: o b j. a = b ; o b j. a = o b j. b ; a = o b j. b ; a = b ; Instrukcja zaburza powiązania nazw zmiennych - spowolnienie programów. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 68 / 182
69 Dziedziczenie I Dziedziczenie jest w JavaScript najczęściej z użyciem łańcuchowego łączenia prototypów: //X <- Y <- Z function X( ) { t h i s. x = 1 0 ; t h i s. f 1 = function ( ) { return "X()" ; } } function Y( ) { t h i s. y = 1 2 ; t h i s. f 2 = function ( ) { return "Y()" ; } } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 69 / 182
70 Dziedziczenie II function Z ( ) { t h i s. z = 1 4 ; t h i s. f 3 = function ( ) { return "Z()" ; } } // Implementacja dziedziczenia Y. p r o t o t y p e = new X( ) ; Z. p r o t o t y p e = new Y( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 70 / 182
71 Tablice W JavaScript można przechowywać w tablicy wartości różnych typów. Tablice w JavaScript są dynamiczne - mogą zwiększać i zmniejszać swój rozmiar w trakcie działania programu. Indeksy w JavaScript są oparte na 32 bitowych liczbach. Indeksy nie muszą być ciągłe (jest możliwość tworzenia tzw. tablic rzadkich). W JavaScript tablice można traktować jako specjalny rodzaj obiektu, których właściwości są liczbami - dostęp do elementów jest jednak szybszy niż w przypadku właściwości obiektów. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 71 / 182
72 Tworzenie tablic I Literały tablicowe - elementy rozdzielane przecinkami zapisane w nawiasach kwadratowych. var pusta = [ ] ; var tab1 = [ 1, 2, 3, 4 ] ; var tab2 = [ 1, f a l s e, 1. 1, "x" ] ; var tab3 = [ [ 1, 2. 0 ], 1 2 ] ; var tab4 = [ { a : 1, b : 2 }, [ 1, 2 ] ] ; var tab5 = [ 1,, 2 ] ; // Rozmiar tab6 3 a nie 4 - dopuszczalny jest // zapis dodatkowego nadmiarowego przecinka var tab6 = [,,, ] ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 72 / 182
73 Tworzenie tablic II Tworzenie tablic z wykorzystaniem konstruktora tablicowego tablica pusta: var tab1 = new Array ( ) ; tablica o określonym rozmiarze - rezerwuje tylko pamięć nie są tworzone elementy ani właściwości. Rozmiarem może być zmienna: var n = 1 0 ; var tab2 = new Array ( n ) ; jawne przekazanie elementów do konstruktora (musi być więcej niż jeden element): var tab3 = new Array ( 1, 2, 3, 4, 5 ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 73 / 182
74 Dostęp do elementów tablic I Dostęp do elementów tablicy jest realizowany z wykorzystaniem operatora indeksowania. Dostęp do nieistniejących indeksów nie skutkuje błędem, lecz zwraca wartość undefined; var tab = [ 1, 2 ] ; tab [ 1 0 ] tab [ 2] Zapis do elementu pod nieistniejącym indeksem skutkuje powstaniem nowego elementu w tablicy. var tab = [ 1, 2 ] ; tab [ 1 0 ] = 100; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 74 / 182
75 Dostęp do elementów tablic II Indeksem są z reguły dodatnie liczby całkowite - ale są również dopuszczalne inne wartości: łańcuchy znaków - jeżeli da się go skonwertować do liczby to jest używany jako indeks, jeżeli nie jest tworzona właściwość o takiej nazwie. liczba ujemna - tworzona jest właściwość o nazwie będącej łańcuchem przechowującym znakową reprezentację tej liczby. liczba rzeczywista - jeżeli nie posiada części ułamkowej to jest traktowana jako indeks, w przeciwnym razie zasady są takie same jak dla liczby ujemnej. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 75 / 182
76 Dostęp do elementów tablic III tab = [ 1, 2 ] ; // tworzona jest właściwość "1.2" tab [ 1. 2 ] = 1 0 ; // element o indeksie 100 tab [ "100" ] = 1 2 ; // tworzona jest właściwość "-1.2" tab [ 1.2] = 120; // tworzona jest właściwość "-1" tab [ 1] = 1 2 ; // dostęp do drugiego elementu tab [ 1. 0 ] = 1 0 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 76 / 182
77 Rozmiar tablicy I Liczbę elementów w tablicy gęstej można poznać za pomocą właściwości length. W przypadku tablic rzadkich zwróci o jeden większy maksymalny możliwy indeks. Właściwość daję się ustawiać w przypadku mniejszych wartości od bieżącego rozmiaru nadmiarowe elementy są usuwane, w przypadku większych wartości od bieżącego rozmiaru zmienia się tylko wartość właściwości, nie są dostawiane żadne dodatkowe elementy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 77 / 182
78 Rozmiar tablicy II // tab. length == 3 tab = [ 1, 2, 3 ] // length wynosi 2, ale nie ma ż adnych element ów tab2 = [,, ] // length wynosi 5, ale nie ma ż adnych element ów tab3 = new Array ( 5 ) ; // length po wykonaniu tych instrukcji wynosi 11, // Jest tylko jeden element tab4 = [ ] tab4 [ 1 0 ] = 1 2 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 78 / 182
79 Rozmiar tablicy III tab5 = [ 1, 2, 3, 4 ] ; // Nadal tylko 4 elementy tab5. l e n g t h = 1 0 ; // Teraz już tylko 3 tab5. l e n g t h = 3 ; // Teraz tablica pusta tab5. l e n g t h = 0 ; // Odpowiednik tab5 = new Array(20); // Nie są tworzone elementy tab5. l e n g t h = 2 0 ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 79 / 182
80 Iterowanie elementów tablicy I Najczęściej przechodzi się po elementach tablicy z wykorzystaniem pętli for w postaci: var tab = [ 1, 2, 3, 4 ] ; f o r ( var i = 0 ; i < tab. l e n g t h ; ++i ) { c o n s o l e. l o g ( tab [ i ] ) ; } // lub wersja szybsza var tab = [ 1, 2, 3, 4 ] ; var r o z m i a r = tab. l e n g t h ; f o r ( var i = 0 ; i < r o z m i a r ; ++i ) { c o n s o l e. l o g ( tab [ i ] ) ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 80 / 182
81 Iterowanie elementów tablicy II W sytuacji, gdy konieczne jest pominięcie elementów niezdefiniowanych lub nieistniejących, należy dodać dodatkowy test na te wartości (w komentarzu pominięcie również wartości null): var tab = [ 1,, 3, 4 ] ; f o r ( var i = 0 ; i < tab. l e n g t h ; ++i ) { // if(! tab[i]) continue; i f ( tab [ i ] === undefined ) c o n t i n u e ; c o n s o l e. l o g ( tab [ i ] ) ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 81 / 182
82 Iterowanie elementów tablicy III Należy unikać pętli for - in - wynika to z tego, że będą również wyświetlane wartości odziedziczone po Array.prototype. Można je jednak odfiltrować za pomocą: f o r ( var e l i n tab ) { i f (! tab. hasownproperty ( e l ) ) c o n t i n u e ; c o n s o l e. l o g ( e l ) ; } Nie ma gwarancji, w jakim porządku będą wyświetlane elementy! dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 82 / 182
83 Metody tablic I concat() - tworzy i zwraca nową tablicę złożoną z połączonej pierwotnej tablicy i argumentów. Spłaszcza najbardziej zewnętrzne tablice przekazywane w ten sposób (ich elementy są wstawiane jako kolejne elementy nowej tablicy). var tab = [ 1, 2, 3 ] ; //Zwraca [1,2,1,2] tab. concat ( 1, 2 ) ; //Zwraca [1,2,1,2] tab. concat ( [ 1 ], [ 2 ] ) ; //Zwraca [1,2,1,[2]] tab. concat ( [ 1 ], [ [ 2 ] ] ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 83 / 182
84 Metody tablic II indexof() i lastindexof() zwracają indeks pierwszego (lub ostatniego) wystąpienia określonej parametrem wartości (lub -1, jeżeli elementu o takiej wartości nie ma w tablicy): var tab = [ 1, 2, 3, 4 ] ; tab. indexof ( 2 ) ; //1 tab. indexof (10) ; // -1 join() - łączy elementy tablicy w łańcuch znaków (opcjonalny parametr - separator): var tab = [ 1, 2, 3, 4 ] ; tab. j o i n ( ) ; // 1,2,3,4 tab. j o i n ( " " ) ; // dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 84 / 182
85 Metody tablic III slice() - tworzy wycinek tablicy - tablicę zawierającą elementy podane indeksami. tostring() - tworzy łańcuch reprezentujący tablicę i jej elementy. pop() - usuwa ostatni element tablicy i zwraca go. push() - dodaje nowy element (elementy) na koniec tablicy i zwraca nową długość tablicy. reverse() - odwraca kolejność elementów tablicy. sort() - sortuje zawartość tablicy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 85 / 182
86 Metody tablic IV every() - zwraca prawdę, jeżeli wszystkie elementy spełniają predykat. filter() - tworzy nową tablicę zawierająca elementy, które pasują do filtra. parametr funkcję. shift() - usuwa i zwraca pierwszy element tablicy, some() - zwraca prawdę, jeżeli choć jeden element spełnia predykat. unshift() - dodaje jeden lub więcej elementów na początek tablicy, zwraca nową długość tablicy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 86 / 182
87 Metody tablic V foreach() - wywołuje określoną parametrem funkcję na każdym elemencie tablicy: var tab = [ 1, 2, 3 ] ; //tab == [1,4,9] tab. f o r E a c h ( function ( x, i, t ) { t [ i ] = x x ; } ) ; var sum = 0 [ 1, 2, 3 ]. f o r E a c h ( function ( x ) {sum += x} map() - tworzy nową tablicę zawierającą elementy, które uzyskano aplikując przekazywaną jako argument funkcję do każdego elementu pierwotnej kolekcji: var tab1 = [ 1, 2, 3 ] ; //tab2 == [1,4,9] var tab2 = tab1. map( function ( x ) { return x x ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 87 / 182
88 Metody tablic VI reduce() i reduceright() - łączą kolejne elementy tablicy z użyciem przekazywanej funkcji - tworzy się w ten sposób pojedynczą wartość. Funkcja reduce() łączy elementy do najniższego indeksu, zaś reduceright() od najwyższego. var tab = [ 1, 2, 3, 4 ] ; //suma == 10 var suma = tab. r e d u c e ( function ( x, y ) { return x + y ; }, 0) ; // suma2 == 10 var suma2 = tab. r e d u c e R i g h t ( function ( x, y ) { return x + y ; }, 0 ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 88 / 182
89 Metody tablic VII //t1 == [1,2,3,4] var t1 = tab. r e d u c e ( function ( x, y ) { return x. concat ( y ) ; }, [ ] ) ; //t2 == [4,3,2,1] var t2 = tab. r e d u c e R i g h t ( function ( x, y ) { return x. concat ( y ) ; }, [ ] ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 89 / 182
90 Wyrażenia regularne I Wyrażenie regularne jest obiektem opisującym ciąg znaków. Wyrażenia regularne są użyteczne przy wyszukiwaniu ciągów znaków lub zamiany ciągów znaków W JavaScript wyrażenia regularne opisuje typ RegExp. JavaScript implementuje składnię wyrażeń regularnych Perla (większość elementów została przejęta z tego języka). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 90 / 182
91 Wyrażenia regularne II Wyrażenia regularne definiuje się korzystając z ukośnika (slash /) lub z konstruktora typu: var wzorzec = /ˆA/ ; var wzorzec2 = new RegExp ( "^A" ) ; Dopuszczalne jest użycie flag: i - dopasowanie niezależne od wielkości liter, g - wyszukanie wszystkich dopasowań a nie tylko jednego, m - tryb wieloliniowy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 91 / 182
92 Klasy znaków Symbol Co dopasowuje [...] Dowolny znak w nawiasach [^...] Dowolny znak niewymieniony w nawiasach. Dowolny znak (oprócz znaku nowego wiersza) \w Znak ASCII (cyfra, litera, znak podkreślenia) \W Znak, który nie jest znakiem ASCII. \s Biały znaku Unicode. \S Dowolny znak, który nie jest białym znakiem Unicode \d Cyfra ASCII \D Dowolny znak różny od cyfry ASCII. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 92 / 182
93 Powtórzenia Symbol Znaczenie {n,m} Dopasowanie co najmniej n razy, lecz nie więcej niż m {n,} Dopasowanie n lub więcej razy {n} Dopasowanie dokładnie n razy? Opcjonalne dopasowanie + Dopasowanie jeden lub więcej razy * Dopasowanie zero lub więcej razy. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 93 / 182
94 Grupowanie i alternacja Symbol Znaczenie Dopasowanie do prawego lub lewego podwyrażenia (...) Grupowanie i numerowanie - zapamiętana grupa może być później użyta (?:...) Tylko grupowanie \num Dopasowanie do tych samych znaków jak w przypadku grupy num dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 94 / 182
95 Dopasowanie do określonej pozycji Symbol Znaczenie ^ Dopasowanie do początku linii lub łańcucha $ Dopasowanie do końca linii lub łańcucha \b Dopasowanie do granicy słowa \B Dopasowanie do pozycji, która nie jest granicą słowa (?= p) Pozytywne przeglądanie do przodu - wymagane dopasowanie do ciągu, ale ciąg nie jest konsumowany (?! p) Negatywne przeglądanie do przodu - wymagany brak dopasowania do ciągu, ciąg nie jest konsumowany dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 95 / 182
96 Przykłady I /\d {1,4}/ //"1" "12" "1234" /\d{4}/ //"1234" /\ s+domek\ s / //" domek" " domek " // "for" ale nie "forma", "bufor", "aforyzm" /\ b f o r \b \ b i f \b \ b w h i l e \b/ // a "b" / ( [ "])[^ "]*\1/ dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 96 / 182
97 Metody łańcuchów współpracujące z wyrażeniami regularnymi I Z wyrażeniami regularnymi współpracują metody łańcuchów znakowych - search(), replace(), match() i split(). Metoda search() umożliwia odszukanie indeksu, od którego rozpoczyna się wyraz dopasowujący do danego wyrażenia regularnego (lub -1, jeżeli takiego nie znajdzie): "MOLEK". s e a r c h ( / [AO] l e k / i ) ; //1 dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 97 / 182
98 Metody łańcuchów współpracujące z wyrażeniami regularnymi II Metoda replace() zwróci łańcuch, w którym zastąpi wyraz dopasowujący do określonego wyrażenia regularnego ciągiem przekazanym jako drugi argument (dozowolone jest użycie znaku $, za którym następuje cyfra): var t e k s t = "a b c d e" ; // Zwróci "a, b, c, d, e" t e k s t. r e p l a c e (/(\ s+)/g,,$1); dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 98 / 182
99 Metody łańcuchów współpracujące z wyrażeniami regularnymi III Metoda match() - umożliwia przekazanie jako argument wyrażenia regularnego i zwraca tablicę zawierającą wyniki dopasowania (rozróżnia globalne i nieglobalne przeszukiwanie). t e k s t = "abc@gmail.com" //[ abc@gmail.com, abc, gmail.com, // index: 0, input: abc@gmail.com ] t e k s t. match (/(\w+)@(\ S+)/) //[ abc@gmail.com ] t e k s t. match (/(\w+)@(\ S+)/g ) dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/14 99 / 182
100 Metody łańcuchów współpracujące z wyrażeniami regularnymi IV Metoda split() umożliwia podział łańcucha znaków względem granicy określonej wyrażeniem regularnym (zwraca tablicę łańcuchów znaków): var t e k s t = " " ; //[ 1234, 456, 789, ] t e k s t. s p l i t (/\ s +/) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
101 Metody wyrażeń regularnych I Typ RegExp definiuje dwie metody pozwalające na wykonywanie operacji z wykorzystaniem wzorców - exec(), test(). Działanie metody exec() - działa podobnie jak match(), ale zwraca tablicę znaków o takiej samej postaci - ustawiane są właściwości index i lastindex. W przypadku wyszukiwania globalnego, w kolejnej iteracji dopasowanie zaczyna się od pozycji lastindex. Metoda test() pozwala na sprawdzenie czy dane wyrażenie regularne dopasowuje do jakiegoś fragmentu łańcucha znaków (zwraca wartość logiczną). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
102 Metody wyrażeń regularnych II var t e k s t = "JavaScript jest bardziej zakręcony\ od języka Java" ; var wzorzec = / Java /g ; var wynik ; while ( ( wynik = wzorzec. exec ( t e k s t ) )!= n u l l ) { c o n s o l e. l o g ( wynik [ 0 ] ) ; } wzorzec. t e s t ( t e k s t ) ; //true dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
103 Nowości w JavaScript 6 I Zasięg blokowy ECMAScript 5 var tab = [ ] ; f o r ( var i = 0 ; i < 5 ; ++i ) { tab [ i ] = function ( ) { c o n s o l e. l o g ( "Numer" + i ) ; } ; } //Numer 4 tab [ 2 ] ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
104 Nowości w JavaScript 6 II ECMAScript 6 var tab = [ ] ; f o r ( var i = 0 ; i < 5 ; ++i ) { l e t nr = i ; tab [ i ] = function ( ) { c o n s o l e. l o g ( "Numer" + nr ) ; } ; } //Numer 2 tab [ 2 ] ( ) ; dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
105 Nowości w JavaScript 6 III Stałe c o n s t EULER = // Nie powiedzie się EULER = 0. 5 Parametry domyślne funkcji function fun ( x, y ) { i f ( x === undefined ) x = 1 ; i f ( y === undefined ) y = 2 ; return x + y ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
106 Nowości w JavaScript 6 IV function fun ( x, y ) { x = x 1 ; y = y 2 ; } function fun ( x = 1, y = 2) { return x + y ; } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
107 Nowości w JavaScript 6 V Klasy c l a s s Punkt { c o n s t r u c t o r ( x, y ) { t h i s. x = x ; t h i s. y = y ; } d l u g o s c ( ) { return Math. s q r t ( x x + y y ) ; } } dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
108 Document Object Model I Document Object Model (w skrócie DOM) jest podstawowym API do reprezentacji i modyfikacji zawartości dokumentów HTML i XML. Zagnieżdzona struktura dokumentów HTML lub XML jest reprezentowana w DOM za pomocą drzewa obiektów. Drzewo reprezentuje dokument w postaci węzłów przedstawiających tagi HTML (np <body>,<b>) i węzłów reprezentujących tekst. Korzeniem całego drzewa jest dokument jako całość. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
109 Document Object Model II <html> <head> <title>przykład</title> </head> <body> <h1>nagłówek</h1> <p>zawartość <b>strony</b> </p> </body> </html> dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
110 Document Object Model III dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
111 Rodzaje węzłów DOM Dokument - Document HTMLDocument Dane znakowe - CharacterData Text - tekst, Comment - komentarz. Elementy - Element HTMLElement HTMLHeadElement HTMLBodyElement HTMLTableElement... Atrybuty - Attr - reprezentują atrybuty elementów dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
112 Atrybuty węzłów - trawersacja DOM I Najważniejszymi atrybutami węzłów są: parentnode - zawiera węzeł rodzicielski (lub null dla węzłów, które nie mają rodzica), childnodes - tablica tylko do odczytu zawierająca reprezentacje węzłów potomnych, firstchild i lastchild - pierwszy i ostatni potomek węzła (lub null jeśli węzeł nie posiada dzieci), nextsibling, previoussibling - następne i poprzednie rodzeństwo węzła (węzły potomne tego samego węzła są rodzeństwem). Porządek jest określony występowaniem w dokumencie. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
113 Atrybuty węzłów - trawersacja DOM II nodetype -rodzaj węzła Document - 9 Element - 1 Text - 3 Comment - 8 DocumentFragment - 11 nodevalue - zawartość węzła tekstowego lub komentarza (Text i Comment), nodename - nazwa tagu elementu zapisana wielkimi literami. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
114 Atrybuty elementów - trawersacja DOM Elementy przedstawiają tagi HTML - przedstawione właściwości umożliwiają przechodzenie po drzewie dokumentów bez odwiedzania węzłów tekstowych i komentarzy. Najważniejsze właściwości z tej grupy: children - jest to NodeList, ale zawiera tylko obiekty Element. firstelementchild i lastelementchild - podobne jak dla węzła, ale tylko elementy. nextelementsibling i previouselementsibling - rodzeństwo, które jest elementem, childelementcount - liczba elementów potomnych (zwraca to samo co children.length). dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
115 Wybór elementów dokumentu I Do obiektu Document można odwołać się poprzez zmienną globalną document. Przekształcanie elementów jest możliwe dopiero po uzyskaniu odpowiedniego elementu. Dostęp do elementów dokumentów jest możliwy na wiele sposobów: za pomocą atrybutu id, za pomocą atrybuty name, za pomocą wyspecyfikowanej nazwy tagu, za pomocą wyspecyfikowanej klasy arkusza styli, za pomocą dopasowania do wyspecyfikowanego selektora CSS. dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2013/ / 182
Języki interpretowane
Języki interpretowane dr inż. Andrzej Grosser Rok akademicki 2017/18 dr inż. Andrzej Grosser Języki interpretowane Rok akademicki 2017/18 1 / 283 Plan wykładów I 1 Wprowadzenie do języków skryptowych 2
Tworzenie stron internetowych z wykorzystaniem HTM5, JavaScript, CSS3 i jquery. Łukasz Bartczuk
Tworzenie stron internetowych z wykorzystaniem HTM5, JavaScript, CSS3 i jquery Łukasz Bartczuk Moduł 5 Podstawy JavaScript Agenda Czym jest JavaScript? Podstawowe typy danych Zmienne Tablice Funkcje Zakres
Programowanie obiektowe
Programowanie obiektowe Wykład 2: Wstęp do języka Java 3/4/2013 S.Deniziak: Programowanie obiektowe - Java 1 Cechy języka Java Wszystko jest obiektem Nie ma zmiennych globalnych Nie ma funkcji globalnych
Laboratorium Wstawianie skryptu na stroną: 2. Komentarze: 3. Deklaracja zmiennych
1. Wstawianie skryptu na stroną: Laboratorium 1 Do umieszczenia skryptów na stronie służy znacznik: //dla HTML5 ...instrukcje skryptu //dla HTML4 ...instrukcje
Języki skryptowe w programie Plans
Języki skryptowe w programie Plans Warsztaty uŝytkowników programu PLANS Kościelisko 2010 Zalety skryptów Automatyzacja powtarzających się czynności Rozszerzenie moŝliwości programu Budowa własnych algorytmów
JavaScript funkcyjność
JavaScript funkcyjność WWW 9 kwietnia 2014 Możliwości tworzenia dynamicznych stron WWW HTML i CSS. Skrypty CGI (Perl, PHP). Serwery (django, java). Plug-iny. Ksiażka Większość przykładów pochodzi z ksiażki:
1 Podstawy c++ w pigułce.
1 Podstawy c++ w pigułce. 1.1 Struktura dokumentu. Kod programu c++ jest zwykłym tekstem napisanym w dowolnym edytorze. Plikowi takiemu nadaje się zwykle rozszerzenie.cpp i kompiluje za pomocą kompilatora,
Tworzenie Stron Internetowych. odcinek 10
Tworzenie Stron Internetowych odcinek 10 JavaScript JavaScript (ECMAScript) skryptowy język programowania powszechnie używany w Internecie. Skrypty JS dodają do stron www interaktywność i funkcjonalności,
PLAN WYNIKOWY PROGRAMOWANIE APLIKACJI INTERNETOWYCH. KL III TI 4 godziny tygodniowo (4x30 tygodni =120 godzin ),
PLAN WYNIKOWY PROGRAMOWANIE APLIKACJI INTERNETOWYCH KL III TI 4 godziny tygodniowo (4x30 tygodni =120 godzin ), Program 351203 Opracowanie: Grzegorz Majda Tematyka zajęć 1. Wprowadzenie do aplikacji internetowych
Podstawy programowania skrót z wykładów:
Podstawy programowania skrót z wykładów: // komentarz jednowierszowy. /* */ komentarz wielowierszowy. # include dyrektywa preprocesora, załączająca biblioteki (pliki nagłówkowe). using namespace
Kurs programowania. Wykład 1. Wojciech Macyna. 3 marca 2016
Wykład 1 3 marca 2016 Słowa kluczowe języka Java abstract, break, case, catch, class, const, continue, default, do, else, enum, extends, final, finally, for, goto, if, implements, import, instanceof, interface,
JAVAScript w dokumentach HTML (1) JavaScript jest to interpretowany, zorientowany obiektowo, skryptowy język programowania.
IŚ ćw.8 JAVAScript w dokumentach HTML (1) JavaScript jest to interpretowany, zorientowany obiektowo, skryptowy język programowania. Skrypty JavaScript są zagnieżdżane w dokumentach HTML. Skrypt JavaScript
Zmienne, stałe i operatory
Zmienne, stałe i operatory Przemysław Gawroński D-10, p. 234 Wykład 2 4 marca 2019 (Wykład 2) Zmienne, stałe i operatory 4 marca 2019 1 / 21 Outline 1 Zmienne 2 Stałe 3 Operatory (Wykład 2) Zmienne, stałe
TOPIT Załącznik nr 3 Programowanie aplikacji internetowych
Szkolenie przeznaczone jest dla osób chcących poszerzyć swoje umiejętności o tworzenie rozwiązań internetowych w PHP. Zajęcia zostały przygotowane w taki sposób, aby po ich ukończeniu można było rozpocząć
Swift (pol. jerzyk) nowy język programowania zaprezentowany latem 2014 r. (prace od 2010 r.)
Swift (pol. jerzyk) nowy język programowania zaprezentowany latem 2014 r. (prace od 2010 r.) przeznaczony do programowania zarówno pod ios jak i Mac OS X bazuje na logice Objective-C bez kompatybilności
Wykład 2 Składnia języka C# (cz. 1)
Wizualne systemy programowania Wykład 2 Składnia języka C# (cz. 1) 1 dr Artur Bartoszewski -Wizualne systemy programowania, sem. III- WYKŁAD Wizualne systemy programowania Budowa projektu 2 Struktura programu
Uwagi dotyczące notacji kodu! Moduły. Struktura modułu. Procedury. Opcje modułu (niektóre)
Uwagi dotyczące notacji kodu! Wyrazy drukiem prostym -- słowami języka VBA. Wyrazy drukiem pochyłym -- inne fragmenty kodu. Wyrazy w [nawiasach kwadratowych] opcjonalne fragmenty kodu (mogą być, ale nie
Informatyka I. Typy danych. Operacje arytmetyczne. Konwersje typów. Zmienne. Wczytywanie danych z klawiatury. dr hab. inż. Andrzej Czerepicki
Informatyka I Typy danych. Operacje arytmetyczne. Konwersje typów. Zmienne. Wczytywanie danych z klawiatury. dr hab. inż. Andrzej Czerepicki Politechnika Warszawska Wydział Transportu 2019 1 Plan wykładu
PROGRAMOWANIE W ŚRODOWISKU FLASH wykład 2
PROGRAMOWANIE W ŚRODOWISKU FLASH wykład 2 Paweł Woszkowski SWSIM 2009 ADOBE ACTIONSCRIPT Programming language of the Adobe Flash Platform. Originally developed as a way for developers to program interactivity,
Ogólny schemat prostego formularza: A może lepiej zamiast przycisku opartego o input tak:
Ogólny schemat prostego formularza: A może lepiej zamiast przycisku opartego o input tak: accept - typy zawartości MIME akceptowane przez serwer (opcjonalny) accept-charset - zestaw znaków akceptowanych
JAVA. Platforma JSE: Środowiska programistyczne dla języka Java. Wstęp do programowania w języku obiektowym. Opracował: Andrzej Nowak
JAVA Wstęp do programowania w języku obiektowym Bibliografia: JAVA Szkoła programowania, D. Trajkowska Ćwiczenia praktyczne JAVA. Wydanie III,M. Lis Platforma JSE: Opracował: Andrzej Nowak JSE (Java Standard
Laboratorium 03: Podstawowe konstrukcje w języku Java [2h]
1. Typy. Java jest językiem programowania z silnym systemem kontroli typów. To oznacza, że każda zmienna, atrybut czy parametr ma zadeklarowany typ. Kompilator wylicza typy wszystkich wyrażeń w programie
Komentarze w PHP (niewykonywane fragmenty tekstowe, będące informacją dla programisty)
Komentarze w PHP (niewykonywane fragmenty tekstowe, będące informacją dla programisty) // to jest pojedynczy komentarz (1-linijkowy) to jest wielolinijkowy komentarz Budowa "czystego" skryptu PHP (tak
JAVASCRIPT PODSTAWY. opracowanie: by Arkadiusz Gawełek, Łódź
JAVASCRIPT PODSTAWY materiały dydaktyczne dla uczniów słuchaczy opracowanie: 2004-2007 by Arkadiusz Gawełek, Łódź 1. Czym jest JavaScript JavaScript tak naprawdę narodził się w firmie Netscape jako LiveScript,
Rys.2.1. Trzy warstwy stanowiące podstawę popularnego podejścia w zakresie budowy stron internetowych [2]
1. CEL ĆWICZENIA Celem ćwiczenia jest przedstawienie możliwości wykorzystania języka JavaScript do tworzenia interaktywnych aplikacji działających po stronie klienta. 2. MATERIAŁ NAUCZANIA JavaScript tak
Podstawy programowania w języku C
Podstawy programowania w języku C WYKŁAD 1 Proces tworzenia i uruchamiania programów Algorytm, program Algorytm przepis postępowania prowadzący do rozwiązania określonego zadania. Program zapis algorytmu
Lekcja 1. Składnia języka zmienne i podstawowe instrukcje PHP. Do wyświetlania tekstu służy instrukcja echo echo Hello world ;
Do wyświetlania tekstu służy instrukcja echo echo Hello world ; PHP język ze słabą kontrolą typów. W języku php w przeciwieństwie do c++ nie musimy podawać typu zmiennej podczas jej deklaracji. Tworzenie
Cw.12 JAVAScript w dokumentach HTML
Cw.12 JAVAScript w dokumentach HTML Wstawienie skryptu do dokumentu HTML JavaScript jest to interpretowany, zorientowany obiektowo, skryptowy język programowania.skrypty Java- Script mogą być zagnieżdżane
Opis: Instrukcja warunkowa Składnia: IF [NOT] warunek [AND [NOT] warunek] [OR [NOT] warunek].
ABAP/4 Instrukcja IF Opis: Instrukcja warunkowa Składnia: IF [NOT] warunek [AND [NOT] warunek] [OR [NOT] warunek]. [ELSEIF warunek. ] [ELSE. ] ENDIF. gdzie: warunek dowolne wyrażenie logiczne o wartości
Platformy Programistyczne Podstawy języka Java
Platformy Programistyczne Podstawy języka Java Agata Migalska 6 maja 2014 Plan wykładu 1 Sztuka wysławiania się w języku Java 2 Cały świat jest obiektem 3 Kolekcje 4 Zmienne i metody statyczne 5 Słowo
Wykład 8: klasy cz. 4
Programowanie obiektowe Wykład 8: klasy cz. 4 Dynamiczne tworzenie obiektów klas Składniki statyczne klas Konstruktor i destruktory c.d. 1 dr Artur Bartoszewski - Programowanie obiektowe, sem. 1I- WYKŁAD
Programowanie obiektowe
Programowanie obiektowe Język programowania Ruby Marcin Młotkowski 12 kwietnia 2018 Plan wykładu 1 Wstęp 2 Typy numeryczne Łańcuchy znaków (klasa String) Przedziały Tablice i tablice asocjacyjne Nazwy
Podstawy programowania w języku C i C++
Podstawy programowania w języku C i C++ Część czwarta Operatory i wyrażenia Autor Roman Simiński Kontakt roman.siminski@us.edu.pl www.us.edu.pl/~siminski Niniejsze opracowanie zawiera skrót treści wykładu,
Strona główna. Strona tytułowa. Programowanie. Spis treści. Sobera Jolanta 16.09.2006. Strona 1 z 26. Powrót. Full Screen. Zamknij.
Programowanie Sobera Jolanta 16.09.2006 Strona 1 z 26 1 Wprowadzenie do programowania 4 2 Pierwsza aplikacja 5 3 Typy danych 6 4 Operatory 9 Strona 2 z 26 5 Instrukcje sterujące 12 6 Podprogramy 15 7 Tablice
1 Podstawy c++ w pigułce.
1 Podstawy c++ w pigułce. 1.1 Struktura dokumentu. Kod programu c++ jest zwykłym tekstem napisanym w dowolnym edytorze. Plikowi takiemu nadaje się zwykle rozszerzenie.cpp i kompiluje za pomocą kompilatora,
Programowanie strukturalne. Opis ogólny programu w Turbo Pascalu
Programowanie strukturalne Opis ogólny programu w Turbo Pascalu STRUKTURA PROGRAMU W TURBO PASCALU Program nazwa; } nagłówek programu uses nazwy modułów; } blok deklaracji modułów const } blok deklaracji
JAVAScript w dokumentach HTML (1)
JAVAScript w dokumentach HTML (1) JavaScript jest to interpretowany, zorientowany obiektowo, skryptowy język programowania. Skrypty JavaScript mogą być zagnieżdżane w dokumentach HTML. Instrukcje JavaScript
METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE. Wykład 02
METODY I JĘZYKI PROGRAMOWANIA PROGRAMOWANIE STRUKTURALNE Wykład 02 NAJPROSTSZY PROGRAM /* (Prawie) najprostszy przykład programu w C */ /*==================*/ /* Między tymi znaczkami można pisać, co się
Dr inż. Grażyna KRUPIŃSKA. D-10 pokój 227 WYKŁAD 7 WSTĘP DO INFORMATYKI
Dr inż. Grażyna KRUPIŃSKA Grazyna.Krupinska@fis.agh.edu.pl D-10 pokój 227 WYKŁAD 7 WSTĘP DO INFORMATYKI Wyrażenia 2 Wyrażenia w języku C są bardziej elastyczne niż wyrażenia w jakimkolwiek innym języku
Język programowania Scala / Grzegorz Balcerek. Wyd. 2. Poznań, cop Spis treści
Język programowania Scala / Grzegorz Balcerek. Wyd. 2. Poznań, cop. 2016 Spis treści Przedmowa 1 Stosowana notacja 1 1. Wprowadzenie 3 1.1. Konsola interaktywna języka Scala 3 1.2. Zmienne 5 1.3. Wartości
Python wprowadzenie. Warszawa, 24 marca PROGRAMOWANIE I SZKOLENIA
Python wprowadzenie Warszawa, 24 marca 2017 Python to język: nowoczesny łatwy w użyciu silny można pisać aplikacje Obiektowy klejący może być zintegrowany z innymi językami np. C, C++, Java działający
Podstawy Programowania C++
Wykład 3 - podstawowe konstrukcje Instytut Automatyki i Robotyki Warszawa, 2014 Wstęp Plan wykładu Struktura programu, instrukcja przypisania, podstawowe typy danych, zapis i odczyt danych, wyrażenia:
JavaScript. Wstęp do podstaw elementów. dr inż. Paweł Boiński, Politechnika Poznańska
JavaScript Wstęp do podstaw elementów dr inż. Paweł Boiński, Politechnika Poznańska Wprowadzenie Historia Maj 1995-10 dni, Mocha, Netscape Wrzesień 1995 - Mocha -> LiveScript Grudzień 1995 - LiveScript
KOTLIN. Język programowania dla Androida
KOTLIN Język programowania dla Androida Historia Kotlin został opracowany przez firmę JetBrains Prace rozpoczęto w 2011 r., od 2012 r. dostępny na licencji Apache 2. Nazwa pochodzi od wyspy koło Petersburga
Podstawy programowania. Podstawy C# Tablice
Podstawy programowania Podstawy C# Tablice Tablica to indeksowany zbiór elementów Tablica jest typem referencyjnym (deklaracja tworzy tylko referencję, sama tablica musi być utworzona oddzielnie, najprościej
Zajęcia 4 - Wprowadzenie do Javascript
Zajęcia 4 - Wprowadzenie do Javascript Co to jest Javascript Javascript jest językiem skryptowym pozwalającym na dołączanie dodatkowej funkcjonalności do stron WWW. Jest ona najczęściej związana z modyfikacją
Krótki kurs JavaScript
Krótki kurs JavaScript Java Script jest językiem wbudowanym w przeglądarkę. Gdy ma się podstawy nabyte w innych językach programowania jest dość łatwy do opanowania. JavaScript jest stosowany do powiększania
Umieszczanie kodu. kod skryptu
PHP Definicja PHP jest językiem skryptowym służącym do rozszerzania możliwości stron internetowych. Jego składnia jest bardzo podobna do popularnych języków programowania C/C++, lecz jest bardzo uproszczona
Skrypty i funkcje Zapisywane są w m-plikach Wywoływane są przez nazwę m-pliku, w którym są zapisane (bez rozszerzenia) M-pliki mogą zawierać
MatLab część III 1 Skrypty i funkcje Zapisywane są w m-plikach Wywoływane są przez nazwę m-pliku, w którym są zapisane (bez rozszerzenia) M-pliki mogą zawierać komentarze poprzedzone znakiem % Skrypty
Wykład 3 Składnia języka C# (cz. 2)
Wizualne systemy programowania Wykład 3 Składnia języka C# (cz. 2) 1 dr Artur Bartoszewski -Wizualne systemy programowania, sem. III- WYKŁAD Wizualne systemy programowania Metody 2 Metody W C# nie jest
Właściwości i metody obiektu Comment Właściwości
Właściwości i metody obiektu Comment Właściwości Właściwość Czy można zmieniać Opis Application nie Zwraca nazwę aplikacji, która utworzyła komentarz Author nie Zwraca nazwę osoby, która utworzyła komentarz
Podstawy programowania. Wykład Funkcje. Krzysztof Banaś Podstawy programowania 1
Podstawy programowania. Wykład Funkcje Krzysztof Banaś Podstawy programowania 1 Programowanie proceduralne Pojęcie procedury (funkcji) programowanie proceduralne realizacja określonego zadania specyfikacja
SUM Edukacja Techniczno Informatyczna Języki i Systemy Programowania. Wykład 3. dr Artur Bartoszewski - WYKŁAD: Języki i Systemy Programowania,
SUM Edukacja Techniczno Informatyczna Języki i Systemy Programowania Wykład 3 1 SUM Edukacja Techniczno Informatyczna Języki i Systemy Programowania Przykład Bingo 2 Treść przykładu Jak wygląda karta do
Oczywiście plik musi mieć rozszerzenie *.php
Oczywiście plik musi mieć rozszerzenie *.php Znaczniki PHP komunikują serwerowi gdzie rozpoczyna się i kończy kod PHP. Tekst między nimi jest interpretowany jako kod PHP, natomiast poza nimi jako kod HTML.
Stałe definiuje się używając funkcji define. Przykład: define( PODATEK, 22); define( INSTALACJAOS, 70); define( MS, Microsoft );
Stałe definiuje się używając funkcji define. Przykład: define( PODATEK, 22); define( INSTALACJAOS, 70); define( MS, Microsoft ); Dobrą praktyką jest używanie wielkich liter jako nazw stałych. Nie jest
Język programowania DELPHI / Andrzej Marciniak. Poznań, Spis treści
Język programowania DELPHI / Andrzej Marciniak. Poznań, 2012 Spis treści Przedmowa 11 Przyjęta notacja 13 Rozdział 1. Wprowadzenie 15 1.1. Ogólne zasady programowania zorientowanego obiektowo 15 1.2. Historia
Myśl w języku Python! : nauka programowania / Allen B. Downey. Gliwice, cop Spis treści
Myśl w języku Python! : nauka programowania / Allen B. Downey. Gliwice, cop. 2017 Spis treści Przedmowa 11 1. Jak w programie 21 Czym jest program? 21 Uruchamianie interpretera języka Python 22 Pierwszy
Test przykładowy 2 PAI WSB Wrocław /06/2018
Imię i Nazwisko: Student ID: Part 1: (Prawda lub Fałsz (T lub F)) 15. Która z poniższych deklaracji funkcji jest nieprawidłowa: A. function Sum(a, b, c){; B. function Sum(var a, var b); C. function Sum(a){;
Dokumentacja do API Javy.
Dokumentacja do API Javy http://java.sun.com/j2se/1.5.0/docs/api/ Klasy i obiekty Klasa jest to struktura zawierająca dane (pola), oraz funkcje operujące na tych danych (metody). Klasa jest rodzajem szablonu
Dynamiczne przetwarzanie stron. dr Beata Kuźmińska-Sołśnia
Dynamiczne przetwarzanie stron dr Beata Kuźmińska-Sołśnia KLIENT Witaj INTERNET SERWER Plik HTML Witaj wyświetlanie przez przeglądarkę Witaj! Serwer WWW komputer
Język JAVA podstawy. Wykład 3, część 3. Jacek Rumiński. Politechnika Gdańska, Inżynieria Biomedyczna
Język JAVA podstawy Wykład 3, część 3 1 Język JAVA podstawy Plan wykładu: 1. Konstrukcja kodu programów w Javie 2. Identyfikatory, zmienne 3. Typy danych 4. Operatory, instrukcje sterujące instrukcja warunkowe,
Swift (pol. jerzyk) nowy język programowania zaprezentowany latem 2014 r. (prace od 2010 r.)
Swift (pol. jerzyk) nowy język programowania zaprezentowany latem 2014 r. (prace od 2010 r.) przeznaczony do programowania zarówno pod ios jak i Mac OS X bazuje na logice Objective-C bez kompatybilności
JAVA W SUPER EXPRESOWEJ PIGUŁCE
JAVA W SUPER EXPRESOWEJ PIGUŁCE Obiekt Obiekty programowe to zbiór własności i zachowań (zmiennych i metod). Podobnie jak w świecie rzeczywistym obiekty posiadają swój stan i zachowanie. Komunikat Wszystkie
Techniki programowania INP001002Wl rok akademicki 2018/19 semestr letni. Wykład 3. Karol Tarnowski A-1 p.
Techniki programowania INP001002Wl rok akademicki 2018/19 semestr letni Wykład 3 Karol Tarnowski karol.tarnowski@pwr.edu.pl A-1 p. 411B Plan prezentacji Abstrakcja funkcyjna Struktury Klasy hermetyzacja
Informatyka I. Klasy i obiekty. Podstawy programowania obiektowego. dr inż. Andrzej Czerepicki. Politechnika Warszawska Wydział Transportu 2018
Informatyka I Klasy i obiekty. Podstawy programowania obiektowego dr inż. Andrzej Czerepicki Politechnika Warszawska Wydział Transportu 2018 Plan wykładu Pojęcie klasy Deklaracja klasy Pola i metody klasy
JAVAScript w dokumentach HTML - przypomnienie
Programowanie obiektowe ćw.1 JAVAScript w dokumentach HTML - przypomnienie JavaScript jest to interpretowany, zorientowany obiektowo, skryptowy język programowania. Skrypty JavaScript są zagnieżdżane w
Java EE produkcja oprogramowania
Java EE produkcja oprogramowania PPJ PODSTAWY PROGRAMOWANIA W JAVIE PODSTAWY JĘZYKA JAVA 1 Warszawa, 2016Z 2 Ogólna charakterystyka języka Java 3 Java 1/2 Język programowania Java został opracowany przez
JavaScript - korzenie
JavaScript - korzenie Dowiesz się o historii JavaScript, jego dialektach i wersjach. Poznasz złe i dobre strony języka, a gdy zaskoczy Cię działanie któregoś z jego elementów, będziesz wiedział, gdzie
JĘZYKI PROGRAMOWANIA Z PROGRAMOWANIEM OBIEKTOWYM. Wykład 6
JĘZYKI PROGRAMOWANIA Z PROGRAMOWANIEM OBIEKTOWYM Wykład 6 1 SPECYFIKATOR static Specyfikator static: Specyfikator ten powoduje, że zmienna lokalna definiowana w obrębie danej funkcji nie jest niszczona
Języki Programowania II Wykład 3. Java podstawy. Przypomnienie
Języki Programowania II Wykład 3 Java podstawy Przypomnienie Analiza, projektowanie, programowanie, testowanie, wdrażanie Iteracyjnie nie kaskadowo Przypadki użycia = opowiastki o używaniu systemu = wymagania
Wyrażenie include(sciezka_do_pliku) pozwala na załadowanie (wnętrza) pliku do skryptu php. Plik ten może zawierać wszystko, co może się znaleźć w
Wyrażenie include(sciezka_do_pliku) pozwala na załadowanie (wnętrza) pliku do skryptu php. Plik ten może zawierać wszystko, co może się znaleźć w obrębie skryptu. Wyrażenia include() i require() są niemal
PLAN WYNIKOWY PROGRAMOWANIE APLIKACJI INTERNETOWYCH. KL IV TI 6 godziny tygodniowo (6x15 tygodni =90 godzin ),
PLAN WYNIKOWY PROGRAMOWANIE APLIKACJI INTERNETOWYCH KL IV TI 6 godziny tygodniowo (6x15 tygodni =90 godzin ), Program 351203 Opracowanie: Grzegorz Majda Tematyka zajęć 2. Przygotowanie środowiska pracy
Algorytmika i Programowanie VBA 1 - podstawy
Algorytmika i Programowanie VBA 1 - podstawy Tomasz Sokół ZZI, IL, PW Czas START uruchamianie środowiska VBA w Excelu Alt-F11 lub Narzędzia / Makra / Edytor Visual Basic konfiguracja środowiska VBA przy
Programowanie obiektowe
Przygotował: Jacek Sroka 1 Programowanie obiektowe Wykład 3 Java podstawy Przygotował: Jacek Sroka 2 Przypomnienie Analiza, projektowanie, programowanie, testowanie, wdrażanie Iteracyjnie nie kaskadowo
Kurs WWW. Paweł Rajba. pawel@ii.uni.wroc.pl http://pawel.ii.uni.wroc.pl/
Paweł Rajba pawel@ii.uni.wroc.pl http://pawel.ii.uni.wroc.pl/ Spis treści Wprowadzenie Automatyczne ładowanie klas Składowe klasy, widoczność składowych Konstruktory i tworzenie obiektów Destruktory i
SWIFT. Zaawansowane Programowanie Obiektowe
SWIFT Zaawansowane Programowanie Obiektowe Swift (pol. jerzyk) nowy język programowania zaprezentowany latem 2014 r. (prace od 2010 r.) przeznaczony do programowania zarówno pod ios jak i Mac OS X bazuje
PHP 5 język obiektowy
PHP 5 język obiektowy Wprowadzenie Klasa w PHP jest traktowana jak zbiór, rodzaj różnych typów danych. Stanowi przepis jak stworzyć konkretne obiekty (instancje klasy), jest definicją obiektów. Klasa reprezentuje
Podstawowe części projektu w Javie
Podstawowe części projektu w Javie Pakiet w Javie to grupa podobnych typów klas, interfejsów i podpakietów. Pakiet w Javie może być wbudowany lub zdefiniowany przez użytkownika. Istnieje wiele wbudowanych
PHP: bloki kodu, tablice, obiekty i formularze
1 PHP: bloki kodu, tablice, obiekty i formularze SYSTEMY SIECIOWE Michał Simiński 2 Bloki kodu Blok if-else Switch Pętle Funkcje Blok if-else 3 W PHP blok if i blok if-else wyglądają tak samo i funkcjonują
Należy ściągnąć oprogramowanie Apache na platformę
Programowanie Internetowe Język PHP - wprowadzenie 1. Instalacja Oracle+Apache+PHP Instalacja Apache, PHP, Oracle Programy i ich lokalizacja Oracle Database 10g Express Edition10.2 http://www.oracle.com/technology/products/database/
JS:Obiekty, tablice, JSON
1 JS:Obiekty, tablice, JSON SYSTEMY SIECIOWE Michał Simiński 2 Obiekty i takblice Jak to wygląda z tymi obiektami? Tablice w JS Tablice w JS, czyli obiekty Tablice w JS metody Tablice w JS sortowanie Jak
Materiały pomocnicze do wykładu 3 - Elementy języka Java
Materiały pomocnicze do wykładu 3 - Elementy języka Java 1) Typy danych Typy całkowite Typ Rozmiar Zakres przechowywanych danych byte 8 bitów -128 do 127 short 16 bitów -32768 do 32767 int 32 bity -2147483648
JAVASCRIPT PODSTAWY. opracowanie: by Arkadiusz Gawełek, Łódź
JAVASCRIPT PODSTAWY materiały dydaktyczne dla uczniów słuchaczy opracowanie: 2004-2007 by Arkadiusz Gawełek, Łódź 1. Czym jest JavaScript JavaScript tak naprawdę narodził się w firmie Netscape jako LiveScript,
Powtórka algorytmów. Wprowadzenie do języka Java.
Powtórka algorytmów. Wprowadzenie do języka Java. Przypomnienie schematów blokowych BEGIN Readln(a); Readln(b); Suma := 0; IF Suma < 10 THEN Writeln( Suma wynosi:, Suma); ELSE Writeln( Suma większa niż
Programowanie w języku Swift : Big Nerd Ranch guide / Matthew Mathias, John Gallagher. Gliwice, cop Spis treści
Programowanie w języku Swift : Big Nerd Ranch guide / Matthew Mathias, John Gallagher. Gliwice, cop. 2017 Spis treści Wprowadzenie 13 Poznawanie języka Swift 13 Dokąd zmierza Objective-C? 13 Przygotowania
Programowanie obiektowe
Programowanie obiektowe Wykład 2 Marcin Młotkowski 4 marca 2015 Plan wykładu 1 2 3 4 5 Marcin Młotkowski Programowanie obiektowe 2 / 47 Krótki opis C Obiektowy, z kontrolą typów; automatyczne odśmiecanie;
MATERIAŁY DO ZAJĘĆ II
MATERIAŁY DO ZAJĘĆ II Zmienne w C# Spis treści I. Definicja zmiennej II. Hierarchia typów (CTS) III. Typy wbudowane IV. Deklaracja zmiennych V. Literały VI. Pobieranie i wypisywanie wartości zmiennych
1. Wartość, jaką odczytuje się z obszaru przydzielonego obiektowi to: a) I - wartość b) definicja obiektu c) typ oboektu d) p - wartość
1. Wartość, jaką odczytuje się z obszaru przydzielonego obiektowi to: a) I - wartość b) definicja obiektu c) typ oboektu d) p - wartość 2. Poprawna definicja wskażnika b to: a) float *a, **b = &a; b) float
Podstawy Programowania Podstawowa składnia języka C++
Podstawy Programowania Podstawowa składnia języka C++ Katedra Analizy Nieliniowej, WMiI UŁ Łódź, 3 października 2013 r. Szablon programu w C++ Najprostszy program w C++ ma postać: #include #include
/* dołączenie pliku nagłówkowego zawierającego deklaracje symboli dla wykorzystywanego mikrokontrolera */ #include <aduc834.h>
Szablon programu: /* dołączenie pliku nagłówkowego zawierającego deklaracje symboli dla wykorzystywanego mikrokontrolera */ #include /* opcjonalne: deklaracja typów o rozmiarze jednego i dwóch
Tablice (jedno i wielowymiarowe), łańcuchy znaków
Tablice (jedno i wielowymiarowe), łańcuchy znaków wer. 8 z drobnymi modyfikacjami! Wojciech Myszka Katedra Mechaniki i Inżynierii Materiałowej 2017-04-07 09:35:32 +0200 Zmienne Przypomnienie/podsumowanie
XML extensible Markup Language. część 5
XML extensible Markup Language część 5 JavaScript Co to jest JavaScript? JavaScript był zaprojektowany w celu dodania interaktywności do stron HTML JavaScript jest językiem skryptowym JavaScript jest zwykle
1. Które składowe klasa posiada zawsze, niezależnie od tego czy je zdefiniujemy, czy nie?
1. Które składowe klasa posiada zawsze, niezależnie od tego czy je zdefiniujemy, czy nie? a) konstruktor b) referencje c) destruktor d) typy 2. Które z poniższych wyrażeń są poprawne dla klasy o nazwie
Spis treści WSTĘP CZĘŚĆ I. PASCAL WPROWADZENIE DO PROGRAMOWANIA STRUKTURALNEGO. Rozdział 1. Wybór i instalacja kompilatora języka Pascal
Spis treści WSTĘP CZĘŚĆ I. PASCAL WPROWADZENIE DO PROGRAMOWANIA STRUKTURALNEGO Rozdział 1. Wybór i instalacja kompilatora języka Pascal 1.1. Współczesne wersje kompilatorów Pascala 1.2. Jak zainstalować
Bazy Danych i Usługi Sieciowe
Bazy Danych i Usługi Sieciowe Język PHP Paweł Witkowski Wydział Matematyki, Informatyki i Mechaniki Jesień 2011 P. Witkowski (Wydział Matematyki, Informatyki i Mechaniki) BDiUS w. VIII Jesień 2011 1 /
Dziedziczenie. Streszczenie Celem wykładu jest omówienie tematyki dziedziczenia klas. Czas wykładu 45 minut.
Dziedziczenie Streszczenie Celem wykładu jest omówienie tematyki dziedziczenia klas. Czas wykładu 45 minut. Rozpatrzmy przykład przedstawiający klasy Student oraz Pracownik: class Student class Pracownik
Jeśli chcesz łatwo i szybko opanować podstawy C++, sięgnij po tę książkę.
Języki C i C++ to bardzo uniwersalne platformy programistyczne o ogromnych możliwościach. Wykorzystywane są do tworzenia systemów operacyjnych i oprogramowania użytkowego. Dzięki niskiemu poziomowi abstrakcji
Instrukcja do ćwiczeń nr 4 typy i rodzaje zmiennych w języku C dla AVR, oraz ich deklarowanie, oraz podstawowe operatory
Instrukcja do ćwiczeń nr 4 typy i rodzaje zmiennych w języku C dla AVR, oraz ich deklarowanie, oraz podstawowe operatory Poniżej pozwoliłem sobie za cytować za wikipedią definicję zmiennej w informatyce.