We współczesnym programowaniu webowym wyróżnić możemy kilka podstawowych rodzajów bibliotek oraz autonomicznych systemów, których używają adepci sztuki tworzenia witryn na całym świecie. Już podczas nauki programowania webowego, bardzo szybko zauważamy istnienie w tym procesie wielu działań, które można automatyzować.

Drzewo dostępnych obecnie technologii webowych oraz gotowych bibliotek do natychmiastowego wykorzystania jest niezwykle rozległe i różnorodne. W obliczu tak wielkiej obfitości i dostępności narzędzi, łatwo jest zagubić się w bogactwie oferowanego nam w sieci oprogramowania. Skrajnie różne, a czasem także sprzeczne bywają również opinie wyrażane przez użytkowników tych systemów.

Dzięki temu e‑materiałowi poznasz najbardziej klasyczne biblioteki oraz gotowe systemy tworzenia witryn dostępne na rynku. Wszystkie omówione narzędzia podzielimy na kilka podstawowych kategorii, aby lepiej zrozumieć przeznaczenie każdego systemu oraz biblioteki.

Do podstawowych kategorii oprogramowania ułatwiającego, bądź automatyzującego pracę początkującego programisty webowego zaliczamy:

  • biblioteki zewnętrzne,

  • systemy CMS,

  • frameworki front‑endowe,

  • frameworkback-endowe,

  • inne pomocne narzędzia i technologie.

Oczywiście same nazwy tych kategorii niewiele powiedzą nam na tym etapie. Pora więc aby po kolei omówić każdy ze wspomnianych rodzajów oprogramowania, a także przytoczyć nazwy wielu najbardziej rozpoznawalnych reprezentantów każdej z kategorii.

Biblioteki zewnętrzne

Najbardziej klasyczną formą wsparcia procesu tworzenia witryny jest użycie bibliotek, czyli plików zewnętrznych zawierających całe zestawy gotowych do użycia funkcji, realizujących konkretne zadania.

Współcześnie, zdecydowanie największa ilość bibliotek używa języka JavaScript, ale wiele gotowych do wykorzystania funkcjonalności stworzono także w innych językach, np. w CSS.

Ciekawostka

Kiedy dany kod źródłowy, realizujący wybrane funkcjonalności, przestaje być zewnętrzną biblioteką, a staje się frameworkiem? Granica bywa płynna, ponieważ ciekawe rozwiązania są często systematycznie rozbudowywane przez społeczności użytkowników do imponujących rozmiarów.

Niemniej jednak, framework to kompleksowy system, który jest dokładnie określonym w detalach projektem zbudowania całej witryny (podobnie jak projekt budowy nowego domu).

Biblioteka zaś to w tej metaforze raczej sklep z gotowymi meblami, narzędziami czy farbami – pomoże nam zrealizować fragment przedsięwzięcia architektonicznego, użyczając wielu narzędzi, bądź gotowych komponentów.

Poznajmy nazwy kilku popularnych bibliotek:

  • jQuery – bardzo obszerna biblioteka, która zmienia i usprawnia wiele istotnych aspektów tworzenia witryny. Zastosowanie jQuery wpływa na sposób używania selektorów w JavaScript – wprowadzono tzw. funkcję główną $(), która upraszcza znacząco wiele zapisów znanych z klasycznego repertuaru JavaScript. Manipulowanie elementami tzw. hierarchii DOMhierarchia DOMhierarchii DOM stało się dzięki jQuery dużo łatwiejsze! Niegdyś dominująca na rynku, dziś powoli i sukcesywnie wypierana z użycia przez najnowsze frameworki front‑endowe, choć niektóre z nich wciąż wykorzystują tę bibliotekę, jak np. Bootstrap;

  • Popper.js – obsługa elementów „wyskakujących” wskutek reakcji na kursor myszki – podpowiedzi, elementy rozwijane, części menu itp.;

  • AOS – akronim od słów: Animate on scroll – biblioteka wykonana w CSS, która zapewnia działanie różnorodnych animacji odtwarzanych podczas przewijania strony;

  • Anime.js – obsługa złożonych animacji za pośrednictwem JavaScript;

  • FullPage.js – umożliwia wykonanie witryny, która pozwoli przewijać zawartość płynnie, lecz zawartość całej witryny na bieżącym ekranie;

  • Masonry.js – zapewnia możliwość użycia w witrynie siatki responsywnych kafelków.

Oczywiście takich pomocnych zestawów funkcji znajdziemy w internecie setki, jeśli nie tysiące. A przecież codziennie powstają nowe. Powyższa lista to jedynie wierzchołek góry lodowej.

Największa zaleta inkludowania (dołączenia) w projekcie biblioteki zewnętrznej to oszczędność czasu programisty i dość niski próg wejścia – uczymy się jak skorzystać z funkcji, niekoniecznie rozumiejąc w jaki sposób realizuje one swoje zadanie. Ponadto, dzięki zapoznaniu się ze sposobem użycia wybranych metod, zyskujemy możliwość wielokrotnego ich wykorzystania w kolejnych projektach.

Wadą podpinania do kodu witryny zewnętrznych plików bibliotek jest występująca siłą rzeczy nadmiarowość kodu źródłowego. Często wykorzystamy jedynie niewielki procent wszystkich dołączanych w bibliotece funkcji. Witryna zawiera wtedy dużo nieużywanego kodu.

Systemy CMS

Skrót CMS to akronim od ang. Content Management System, czyli System Zarządzania Treścią. Jest to instalowany na serwerze kompleksowy pakiet, zawierający architekturę całej gotowej witryny, wraz z dodatkowym, wykonanym również jako strona internetowa panelem administracyjnym. Dostęp do takiego zaplecza witryny powinien posiadać tylko administrator serwisu oraz (w ograniczonym wymiarze) także jego redaktorzy.

Dodawanie nowych treści odbywa się najczęściej z użyciem edytora WYSIWYGedytor WYSIWYGedytora WYSIWYG. System pozwala na instalację wielu gotowych wtyczek (ang. plugin) realizujących konkretne funkcjonalności. Natomiast wygląd strony internetowej można dostosować dzięki istnieniu szablonów (ang. theme).

Jest to zatem „gotowiec” w całym znaczeniu tego słowa. Praca z systemem polega w większości na klikaniu oraz obsłudze formularzy panelu administracyjnego. Pisanie własnego kodu oczywiście jest możliwe, lecz jednocześnie z racji istnienia gotowej struktury systemu, nasze możliwości wpływania na sposób jego działania są mocno ograniczone.

Istnieje za to wśród użytkowników scena tworzenia darmowych lub płatnych szablonów (czyli w praktyce zmiany wyglądu strony) do systemów CMS oraz przydatnych wtyczek. Zdolni programiści sprzedają swoje kompatybilne z systemem dodatki, dbając dodatkowo o zapewnienie zgodności kodu w przypadku aktualizacji.

Do najważniejszych systemów CMS zaliczamy następujące rozwiązania:

  • WordPress – najczęściej używany na świecie. Cechuje go łatwość w obsłudze, duża społeczność twórców oraz żywy rynek tysięcy dostępnych wtyczek i szablonów. Od prostego bloga lub strony wizytówki po rozbudowane portale, czy sklepy internetowe – Wordpress oferuje bogatą różnorodność zastosowań;

  • Joomla! – system dobry do tworzenia portali internetowych, obsługa jego panelu jest jednak nieco trudniejsza i mniej intuicyjna. Z racji mniejszej liczby użytkowników nie oferuje tak olbrzymiej liczby wtyczek i szablonów jak WordPress, stanowi jednak dobrą do niego alternatywę;

  • Drupal – świetny dla użytkowników średniozaawansowanych, do budowy serwisów o rozbudowanych funkcjonalnościach dla użytkowników. Jest trudniejszy w obsłudze i posiada bardziej rozbudowany panel administracyjny, jednak daje dużo więcej możliwości użycia własnego kodu źródłowego.

Największą wadą tego typu gotowych systemów jest nadmiarowość kodu źródłowego, przekładająca się na zwiększoną wagę plików źródłowych, a więc mniejszą szybkość działania w przeglądarce oraz często gorsze wyniki w kontekście SEOSEOkontekście SEO. System zapewniający działanie wielu różnorodnych wtyczek oraz mnóstwa funkcji panelu administracyjnego nigdy nie będzie tak lekki i zoptymalizowany jak dedykowana witryna – to oczywiste.

Największą zaletą takiego kompleksowego systemu jest możliwość rozbudowanej konfiguracji tak wyglądu, jak funkcjonalności witryny bez znajomości podstawowych technologii i języków webowych: HTML, CSS, JS, PHP i SQL. Nawet osoba będąca kompletnym laikiem w dziedzinie programowania będzie w stanie stworzyć poprawnie działającą witrynę.

Natomiast doświadczony programista,  dzięki użyciu gotowych komponentów, zyska możliwość bardzo szybkiego uruchomienia witryny dla klienta. Chętnie także wykorzysta olbrzymi popyt na potrzebne użytkownikom wtyczki lub pięknie wyglądające szablony witryn.

Frameworki front‑endowe

Rozbudowane systemy tworzenia spójnego wyglądu całej witryny w przeglądarce. Niezależnie od pomysłu na konkretny layoutlayoutlayout serwisu, framework określa zachowanie wszystkich jego najważniejszych komponentów interfejsu. Mowa tu między innymi o:

  • rozwiązaniu kwestii responsywności całego układu strony;

  • zapewnieniu intuicyjnej nawigacji z pomocą menu głównego i pobocznego;

  • zorganizowaniu odpowiedniej konfiguracji typografii, w tym skalowania rozmiaru nagłówków i akapitów;

  • określeniu spójnego wyglądu i zachowania podstawowych elementów interfejsów webowych: kontrolek formularzy, tabel, obrazów, bloku cytatu, list numerowanych i nienumerowanych itd.

Reasumując: framework tego typu to zestaw bibliotek, plików oraz innych zasobów, które realizują według przemyślanej filozofii kompleksowy i spójny pomysł na sposób zrealizowania interfejsów współczesnej witryny.

Co ważne, frameworki front‑endowe nie zajmują się serwerową mechaniką działania witryny, lecz przede wszystkim wyglądem widoków i interfejsów serwisu po stronie klienta. Do najpopularniejszych obecnie tego typu systemów zaliczamy:

  • React używający głównie języka JavaScript, a stworzony przez twórców portalu Facebook w zamyśle jako pomocnicza biblioteka dla tego serwisu. W 2013 roku kod został udostępniony użytkownikom i wokół zawartych w nim ciekawych technik (reużywalne komponentyreużywalność komponentówreużywalne komponenty, wirtualna hierarchia DOM) narosła olbrzymia społeczność, która wciąż rozbudowuje i rozszerza zakres jego zastosowania;

  • Angular stworzony w Google, napisany w języku TypeScript, potężny framework, lecz jednocześnie inny strukturalnie od konkurencyjnych rozwiązań - trudniejszy w opanowaniu dla programisty, ma stosunkowo wysoki próg wejścia;

  • Vue.js – jego twórcą jest Evan You, były pracownik Google. Łączy on cechy dwóch wcześniej wymienionych systemów: Angular oraz React, a jednocześnie jest lekki i przyjazny użytkownikowi, to znaczy łatwiejszy do nauki nawet dla początkujących programistów;

  • Bootstrap – początkowo była to biblioteka CSS stworzona przez programistów Twittera, która w ciekawy sposób (z użyciem siatki 12‑kolumnowej) rozwiązała problem responsywności całej struktury witryny w kilku ustalonych z góry klasycznych szerokościach ekranu (dzięki użyciu tzw. media queries w CSS). Oddana użytkownikom zdobyła rzeszę sympatyków i rozrosła się do postaci obecnego, bardzo popularnego w sieci frameworka front‑endowego.

Kilka pozostałych, wartych uwzględnienia na liście systemów (jak widać ich różnorodność jest olbrzymia i wciąż powstają nowe) to: Foundation, Ember.js, Svelte, Semantic‑UI, Backbone.js, Materialize.

Największą zaletą użycia frameworków front‑endowych jest możliwość bardzo szybkiego, kompleksowego zapewnienia poprawnego działania wszystkich najważniejszych komponentów serwisu w przeglądarce po stronie klienta. Witryna jest responsywna, ma dobrze zrealizowaną nawigację, a ponadto zadbano o poprawne działanie wszystkich elementów składowych interfejsów, a nawet optymalizację szybkości procesu renderowania widoku w przeglądarce.

Wadą użycia gotowych szkieletów jest stworzenie witryny, która swoim stylem nie odbiega znacząco od tysięcy innych serwisów stworzonych w tym samym frameworku. Nawet mało wprawne oko od razu rozpozna kolejną witrynę stworzoną np. w Bootstrapie – cechować ją będzie w wielu elementach interfejsu podobieństwo do wielu widzianych w sieci serwisów.

Frameworkback‑endowe

Przeznaczone dla zaawansowanych programistów webowych, kompleksowe systemy realizujące całość serwerowej mechaniki działania serwisu. Wszystkie napisane przez nas funkcjonalności muszą przestrzegać zasad określonych we frameworku – istnienie takiej wspólnej struktury pozytywnie wpływa na jakość i bezpieczeństwo wynikowego kodu.

Tworzenie strony we frameworkback-endowym wymaga wiele wiedzy i doświadczenia. Nie jest to zwykłe pisanie kodu linia po linii, lecz wykorzystanie wielu wysublimowanych technik obiektowych i wzorców projektowych. Skupiamy się nie tyle na działaniu samych funkcji, co raczej na obsłużeniu całego procesu udzielenia odpowiedzi (ang. response) na żądanie HTTP klienta (ang. request).

Użycie frameworkback-endowego nie definiuje w żaden sposób wyglądu serwisu. Natomiast tego typu kompleksowy system całkowicie przejmuje i nadpisuje rdzenne aspekty działania serwerowej mechaniki witryny – tworzymy tu abstrakcyjne modele kontaktu z bazą danych, używamy opartych na dziedziczeniu metod renderowania poszczególnych widoków podstron oraz kierujemy routingiemrouting adresówroutingiem adresów podstron lub kategorii. Często używamy w tych systemach tak zwanego podejścia MVCMVCpodejścia MVC.

Podziału frameworków warto dokonać według języka back-endowego, którego dany system używa:

Używany język programowania

Nazwy frameworków back‑endowych

PHP

Symfony, Laravel, Zend Framework, CodeIgniter, CakePHP, Yii Framework, FuelPHP, Phalcon

Python

Django, Flask, Tornado, Web2py

Ruby

Ruby on Rails, Sinatra

Node.js

Express.js, Hapi.js, Socket.io, Derby.js

Java

Spring, Grails (Apache Groovy)

Zaletą użycia tak rozbudowanych i kompleksowych systemów jest możliwość szybkiego implementowania dobrego jakościowo kodu źródłowego witryny – bezpiecznego, skalowalnego i łatwego w utrzymaniu.

W praktyce, najważniejszą wadą frameworków back-endowych jest dość wysoki próg wejścia w system dla programisty – trzeba zrozumieć wiele konceptów, zasad, wzorców architektonicznych, współzależności oraz ról strukturalnych przypisanych do poszczególnych komponentów i bibliotek. A to wszystko pod warunkiem uprzedniego poznania składni danego języka programowania, którego używa framework!

Inne pomocne narzędzia i technologie

Przy okazji omawiania użycia bibliotek zewnętrznych, frameworków oraz systemów CMS warto wspomnieć także o kilku innych rodzajach narzędzi wspomagających:

  • Build tools, czyli oprogramowanie automatyzujące czynność przygotowania produkcyjnej wersji oprogramowania. Tego typu zdania to na przykład usuwanie znaków białych ze skryptów i arkuszy stylów (co zmniejsza ich rozmiar), optymalizowanie jakości obrazów przy zachowaniu rozsądnego rozmiaru plików albo przeprowadzenie procesów walidacji i kompilacji kodu. Najpopularniejsze tego typu narzędzia to Gulp oraz Grunt;

  • Systemy kontroli wersji, które pomagają zachować porządek wprowadzanych w projekcie zmian, szczególnie gdy tworzony jest przez zespół ludzi. Dzięki istnieniu repozytorium zyskujemy kontrolę nad historią modyfikacji plików źródłowych. Najpopularniejszą na świecie usługą tego typu jest portal GitHub, wykorzystujący system kontroli wersji o nazwie Git;

  • Systemy zarządzania pakietami, czyli narzędzia automatycznie pobierające, instalujące i konfigurujące pakiety potrzebnego w danym projekcie oprogramowania. Dbają one także o aktualizacje oraz zapewniają możliwość usuwania pakietów. Kilka często użytkowanych tego typu narzędzi w kontekście programowania webowego to: npm, bower, composer.

Po zakończeniu lektury tej części e‑materiału, zachęcamy do zapoznania się z graficzną reprezentacją omówionych systemów i narzędzi, obrazującą praktyczny podział według ich zastosowania.

Słownik

edytor WYSIWYG
edytor WYSIWYG

ang. What you see is what you get – w kontekście webowym określenie edytora, który umożliwia nie tyle pracę z kodem źródłowym HTML, co z wyrenderowanym widokiem witryny; w założeniach, gotowy widok podstrony w przeglądarce klienta, ma być identyczny z prezentowanym w edytorze podglądem

hierarchia DOM
hierarchia DOM

ang. Document Object Model – określony przez organizację W3C standardowy model struktury całego dokumentu HTML, wykorzystywany przez współczesne przeglądarki internetowe; model ten jest obiektowy i niezależny od platformy sprzętowej czy używanego w projekcie języka programowania

SEO
SEO

akronim od ang. Search Engine Optimization – ogół działań, których dokonują programiści webowi w celu poprawy widoczności witryny w wynikach wyszukiwania - w szczególności w najbardziej popularnej wyszukiwarce Google

layout
layout

inaczej szablon serwisu, czyli układ graficzny witryny internetowej; rozmieszczenie nawigacji, treści właściwej i pobocznej, sposób przewijania zawartości, odgrywane animacje, rozmieszczenie elementów interaktywnych, typografię, kolorystykę i zachowanie na urządzeniu mobilnym

routing adresów
routing adresów

konfiguracja zachowania witryny internetowej w zależności od części składowych adresu URL w żądaniu HTTP; na podstawie struktury adresu kontroler podejmuje decyzję, który widok witryny wyrenderować w odpowiedzi na żądanie (np. konkretny wpis blogowy, stronę główną, wybraną kategorię wpisów itd.)

MVC
MVC

ang. Model View Controller – wzorzec projektowy wykorzystywany w wielu frameworkach; zakłada podział struktury na trzy główne, abstrakcyjne segmenty: model (reprezentacja logiczna rzeczywistości), widoki (interfejsy, warstwa prezentacji) i kontrolery (sterowanie zachowaniem aplikacji)

reużywalność komponentów
reużywalność komponentów

cecha, dzięki której komponenty mogą być bardzo łatwo wykorzystane w różnych miejscach, w różnych kontekstach