CSS – Cascading Style Sheets 1
– Tutoriale, exemple si explicatii din care sa invatati, daca exersati si singuri.
Cuprins Lectii :
1 – Scrierea codului CSS
- Obiectele (regulile) CSS : selector, clasa si identificator.
- Componentele unui obiect CSS
2 – Crearea Foilor de Stil
- Etichete HTML si stiluri CSS
- Definirea selectorilor
- Crearea etichetelor HTML personalizate
- Definirea de reguli similare
- Definirea etichetelor in context (imbricate)
- Cresterea prioritatii unei definitii
- Determinarea ordinii cascadei
- Adaugarea comentariilor la CSS
3 – Configurarea fonturilor
- Stabilirea fontului
- Stabilirea dimensiunii fontului
- Text inclinat
- Grosimea fontului
- Majuscule mici
- Valori multiple pentru font
4 – Configurarea textului
- Spatiul intre litere
- Spatiul dintre cuvinte
- Spatiul intre linii
- Marimea (tipul) literelor
- Alinierea textului
- Alinierea pe verticala a textului
- Formarea paragrafelor
- Aplicarea elementelor decorative
- Spatiile albe
5 – Configurari pentru culori si fundal
- Configurarea fundalului
- Culoarea fundalului
- Imaginea de fundal
- Repetarea imaginii de fundal
- Controlul imaginii de fundal
- Pozitia imaginii de fundal
- Stabilirea simultana a proprietatilor fundalului
- Stabilirea culorii din prim-plan
6 – Controale pentru chenare si afisarea elementelor
- Latimea si inaltimea unui element
- Marginile unui element
- Chenarul unui element
- Adaugarea spatiului in interior in jurul elementului
- Elemente float
- Anularea plasarii unui element in spatiul eliberat de „float”
- Afisarea si ascunderea elementelor
7 – Controale de pozitionare
- Stabilirea modului de pozitionare
- Pozitionarea statica
- Pozitionarea relativa
- Pozitionarea absoluta
- Pozitionarea fixa
- Pozitionarea in raport cu latura de sus, respectiv stanga
- Pozitionarea in raport cu latura de jos, respectiv dreapta
- Pozitionarea in spatiul 3D
- Includerea unui element absolut intr-un element relativ
- Includerea unui element relativ intr-un element absolut
8 – Configurari pentru vizibilitate si mouse
- Stabilirea vizibilitatii unui element
- Stabilirea suprafetei vizibile a unui element
- Definirea pozitiei depasirii
- Aspectul indicatorului de mouse
9 – Pseudo-clasele
- Pseudo-clase cu selector
- Pseudo-clase si clase
- Pseudo-clase cu id-uri si elemente de formular
10 – Pseudo-elemente
- In aceasta lectie invatati ce sunt si ce fac pseudo-elementele
- after, before, first-letter, first-line
CSS3 – Background proprietati noi
• Proprietati noi pt. background, adaugate in CSS3: background-size, background-origin si background-clip.
CSS3 – Border proprietati noi
• Proprietati noi pt. border (bordura), adaugate in CSS3. Rotunjire colturi cu border-radius, adaugare umbra la chenar cu box-shadow, utilizare imagine pt. aspectul bordurii cu border-image.
CSS3 – text-shadow, word-wrap, text-overflow
• Proprietati pentru efecte de text, adaugate in CSS3.
CSS3 opacity
• Setare opacitate si transparenta la elementele HTML cu proprietatea CSS opacity.
CSS3 Transformari 2D
• Transformare elemente HTML in plan 2D (mutare, rotire, redimensionare, distorsie), folosind proprietatea „transform” si metodele: translate(), rotate(), scale(), skew().
CSS3 transition
• Adauga un efect de animatie cand se modifica proprietatile CSS ale unui element HTML, schimband gradual de la un stil la altut.
Introducere
Crearea paginilor HTML este un lucru relativ simplu, invatarea etichetelor HTML si crearea unor imagini ducand la realizarea de pagini web de o complexitate medie. Odata cu dezvoltarea internetului, site-urile au devenit din ce in ce mai complexe, cu un numar mai mare de pagini, cerintele privind grafica si elementele din pagina au devenit mai pretentioase si astfel proiectarea paginilor web a devenit o sarcina ceva mai dificila.
O problema importanta cand avem un site cu multe pagini este atunci cand dorim sa facem anumite schimbari in elementele pagini: fondul, grafica sau fontul textelor din pagini.
Prin utilizarea CSS (Cascading Style Sheets), in traducere „foi de stil in cascada„, acest lucru nu mai este o problema, realizandu-se relativ usor, prin schimbarea sau adaugarea unor elemente in codul CSS, ne fiind nevoi sa lucram la fiecare pagina sau la fiecare element din pagina.
CSS se ocupa in general cu aspectul si controlul grafic al elementelor din pagina, cum ar fi: textul, imaginile, fondul, culorile si asezarea acestora in cadrul ferestrei paginii.
CSS foloseste stiluri, acestea inglobeaza, sub un anumit nume, atribute de formatare care se aplica asupra unui element individual din pagina, asupra unui grup de elemente sau la nivelul intregului document.
CSS functioneaza cu HTML, insa nu este HTML. El extinde functionalitatile HTML, permitand redefinirea etichetelor HTML existente.
Prin utilizarea CSS aspectul documentului pe ansamblu, sau a unui element individual din interiorul sau, poate fi controlat mult mai usor. Stilurile pot fi aplicate asupra unui element, a unui document sau chiar asupra unui intreg site web.
Un dezavantaj ar fi ca unele navigatoare nu sunt compatibile CSS, astfel ca documentele HTML sunt afisate ca si cum CSS n-ar exista, dar cele mai cunoscute si utilizate browsere, cum ar fi: Mozilla Firefox, Internet Explorer, Opera, si altele, sunt compatibile CSS.
Acest curs prezinta elementele de baza CSS si modul de lucru cu „foile de stil”, va invata cum sa adaugati si sa folositi CSS in paginile dv. web.
Tot ce aveti nevoie este un editor de texte simplu, cum ar fi Notepad, si un navigator, de exemplu Mozilla Firefox, care este
Pentru a invata cat mai bine elementele prezentate in aceste lectii, exersati personal fiecare exemplu si proprietate explicata.
Scrierea codului CSS
Codurile CSS pot fi scrise in interiorul paginii sau intr-un fisier extern cu extensia”.css”.
Codul CSS, ca forma generala, este alcatuit din: obiectul care va fi formatat. proprietatile acestuia si valoarea (sau atributele) fiecarei proprietati.
Cand este adaugat in documentul HTML, trebuie scris in cadrul unui tag <style> in sectiunea HEAD a documentului HTML, dupa cum se vede in formula generala de cmai jos;
<html>
<head>
<title>Titlul</title>
<style type=”text/css”>
obiect_css {
proprietate:valoare;
alta_proprietate:valoare;
}
</style>
</head>
<body>
… Continut …
</body>
</html>
– Observati sintaxa codului CSS. Perechile proprietate:valoare se scriu intre acoladele obiectului CSS pe care-l definesc, intre „proprietate” si „valoare” trebuie sa fie un caracter doua-puncte (:) iar la sfarsitul perechii se adauga un caracter punct-si-virgula (;)
– Cand este adaugat intr-un fisier extern „.css”, codul CSS se scrie la fel, dar nu se mai adauga tag-ul <style>.
1. Obiectele (regulile) CSS
Exista trei tipuri principale de obiecte CSS: selector, clasa si identificator.
– Selectorul HTML
Selectorul HTML se foloseste pentru a redefini modul de afisare a continutului etichetei HTML.
Un selector HTML reprezinta partea etichetei HTML care indica navigatorului tipul de eticheta.
Iata un exemplu:
h1 { font-family:”Arial”; font-size:15px; }
– Aici selectorul este „h1”.
Definirea unui selector HTML folosind CSS are ca rezultat redefinirea etichetei HTML. Selectorul si eticheta desi par identice, totusi nu sunt.
– Clasa
Clasa este un obiect care poate fi aplicat oricarei etichete HTML.
O clasa trebuie creata in interiorul etichetei HTML inainte de a fi definita intr-un cod CSS. Crearea clasei in interiorul etichetei se face simplu, prin specificarea cuvantului class si numele clasei, ca in exemplu de mai jos:
- <h1 class=”nume_clasa”> Text </h1>
– „nume_clasa”, poate fi orice nume dorim.
– Apoi in interiorul codului CSS, clasa trebuie definita prin adaugarea unui caracter punct (.) inaintea numelui clasei, ca in exemplu urmator:
.nume_clasa { font-family:”Arial”; font-size:15px; }
Numele aceleasi clase poate fi atribuit mai multor etichete HTML din aceeasi pagina, si toate vor prelua acelasi stil css.
– Identificator
Obiectele de tip identificator (ID) sunt asemanatoare cu clasele. Pot fi aplicate oricarei etichete HTML, dar spre deosebire de clase, numele unui identificator trebuie atribuit numai unei singure etichete HTML dintr-o pagina, pentru alta eticheta se adauga un ID cu nume diferit.
Ca si clasa, identificatoru trebuie intai creat in interiorul etichetei HTML. Modul de creare este simplu, prin specificarea cuvantului id si numele clasei, ca in exemplu de mai jos:
- <h1 id=”nume_id”> Text </h1>
– „nume_id”, poate fi orice nume dorim.
In interiorul codului CSS, identificatorul este definit prin adaugarea unui caracter diez (#) inaintea numelui, ca in exemplu urmator:
#nume_id { font-family:”Arial”; font-size:15px; }
In urmatoarea lectie va fi explicat mai amanuntit modul de definire si rolul acestor obiecte CSS .
2. Componentele unui obiect CSS
Obiectele CSS, indiferent de tipul lor, au in componenta urmatoarele elemente:
- Selectorii – identifica un obiect; pot fi selectori de etichete HTML, clase sau identificatori.
- Proprietatile – identifica o proprietate a obiectului; se refera in special la aspect.
- Valorile – sunt atributele unei proprietati; pot fi cuvinte cheie, valori numerice sau procentuale, tipul valorii depinzand de proprietate.
Sintaxa generala a unei reguli CSS este urmatoarea:
- selector {proprietate: valoare; }
Proprietatile si valorile constituie definitia regulii (obiectului) CSS. Acestea se regasesc sub forma de perechi,despartite de caracterul doua puncte ”:”, fiecare pereche se termina cu un caracter punct si virgula „;”.
Etichetele HTML nu sunt sensibile la diferenta intre majuscule si litere mici. Dar odata cu aparitia limbajului XHTML, acesta face distinctie intre majuscule si minuscule, astfel ca toate etichetele si toti selectorii trebuie scrisi cu litere mici.
Crearea Foilor de Stil
1. Etichete HTML si stiluri CSS
CSS ofera posibilitatea de a schimba aspectul fiecarei etichete in parte, prin stabilirea unui anume stil in interiorul ei, cu atributul „style„. Acest lucru este util mai ales pentru a anula alte stiluri ale elementului respectiv sau de a da elemente grafice de stil doar etichetei respective.
Sintaxa pentru definirea stilurilor in interiorul unei etichete HTML este urmatoarea:
- <eticheta style=”proprietate:valoare;”> text … </eticheta>
CSS permite si definirea unor reguli de stil generale intr-o pagina web. Acest set de reguli trebuie scris in sectiunea de antet (head) a documentului, in cadrul tag-ului <style>.
Sintaxa pentru definirea CSS intr-un document HTML, in interiorul etichetei <head> </head>, este urmatoarea:
- <style type=”text/css”>
selector_1 {proprietate1:valoare1; proprietate2:valoare2; … }
…
selector_n {proprietate1:valoare1; proprietate2:valoare2; … }
</style>
– Definirea tuturor stilurilor intr-o locatie comuna usureaza modificarea mai rapida a unei pagini.
Iata un exemplu practic de cod css:
<style type=”text/css”>
h1 { font-family:’Arial’; font-size:15px; font-weight:bold; color:#1111ff; }
p {font-family:’Arial’; font-size:12px; color:blue; }
</style>
Foile de stil pot fi utilizate nu doar la nivel de pagina web, ci si la nivel de intreg site. Astfel, trebuie creata o foaie de stil externa intr-un fisier separat, de preferat cu extensia „.css”, care poate fi inclus in pagina HTML prin doua procedee: legatura sau import.
Crearea unei foaie de stil externe se face scriind codul CSS intr-un fisier text cu ajutorul unui editor de texte simplu (de exemplu Notepad in Windows), sau specializat in acest sens (precum Notepad++). In fisierul extern creat se adauga reguli CSS, fara insa ca aceste reguli sa fie incadrate in etichete STYLE.
Dupa ce a fost creata foaia de stil externa, aceasta poate fi folosita de un document HTML utilizand urmatoarea sintaxa, in interiorul tag-ului <head> </head>:
- <link rel=”stylesheet” href=”nume_fisier.css” type=”text/css”>
– Eticheta LINK apare in antetul documentului (sectiunea head), iar atributele folosite transmit navigatorului tipul de legatura („rel” – legatura cu o foaie de stil, „type” – tipul codului din fisier) si locatia inspre fisierul ce contine codul CSS („href” – calea si numele complet al fisierului, inclusiv extensia).
O alta modalitate de utilizare a foilor de stil externe intr-un document HTML o reprezinta importul acestora folosind comanda @import.
Sintaxa pentru importul unei foi de stil externe este urmatoarea:
- <style type=”text/css”>
@import url(nume_fisier.css);
</style>
Pentru a importa un fisier CSS extern se foloseste in cadrul sectiunii HEAD a documentului HTML eticheta STYLE. In cadrul acestei etichete este adaugata instructiunea „@import” de mai sus, unde „nume_fisier.css” reprezinta calea si numele fisierului ce contine regulile CSS definite.
Alaturi de instructiunea „@import”, in cadrul etichetei STYLE, pot fi adaugate definiti si selectori suplimentari.
Legatura la un fisier CSS extern sau importul acestuia intr-un document HTML are acelasi efect ca si cum stilurile incluse ar fi fost definire direct in eticheta STYLE din sectiunea HEAD a documentului HTML.
2. Definirea selectorilor
– Selectorii HTML pot fi definiti prin adaugarea unui numar de definitii compatibilie cu eticheta HTML la care se refera, avand urmatoarea forma generala:
- selector_HTML { proprietate1:valoare1; proprietate2:valoare2; … }
Dupa redefinirea etichetei HTML, stilurile etichetelor respective din documentul HTML vor fi modificate automat. Prin redefinirea unei etichete, proprietatile prestabilite existente nu sunt anulate, ci se adauga altele noi.
Utilizarea selectorilor de tip clasa ofera posibilitatea configurarii unor stiluri care se pot aplica doar acelor elemente care sunt etichetate cu clasa respectiva. Sintaxa generala de definire a unei clase CSS este:
- .nume_clasa { proprietate1:valoare1; proprietate2:valoare2; … }
Exista cazul in care o clasa este asociata unui selector HTML, ceea ce inseamna ca acea clasa poate fi folosita doar cu eticheta HTML respectiva. Pentru a defini o clasa care sa afecteze in mod direct un anume selector HTML, se foloseste urmatoarea sintaxa:
- selector_HTML .nume_clasa { proprietate1:valoare1; proprietate2:valoare2; … }
Selectoarele de clasa sunt acceptate de toate navigatoarele. Numele unei clase e recomandat sa fie diferit de cuvantele rezervate JavaScript.
– Asemanator cu selectorii de clasa se definesc si identificatorii (id-ul). Acestia sunt folositi pentru crearea de stiluri care pot fi atribuite unei singure etichete HTML dintr-o pagina. Sintaxa generala de definire a unui identificator este:
- #identificator { proprietate1:valoare1; proprietate2:valoare2; … }
Identificatorii permit definirea unui element sub forma unui obiect, fiind folositi doar o singura data in cadrul unei pagini web pentru identificarea tag-ului respectiv, astfel poate fi manipulat si cu ajutorul functiilor JavaScript.
Numele unui identificator e recomandat sa fie diferit de cuvantele rezervate JavaScript.
3. Crearea etichetelor HTML personalizate
Majoritatea etichetelor HTML au unele proprietati prestabilite. Acestea fie raman asa cum sunt, fie pot fi redefinite. Exista insa cazuri in care se doreste crearea unor etichete personalizate, pornind de la zero. In acest caz se folosesc etichetele <span> si <div>.
Eticheta <span> nu are proprietati mostenite. Ea reprezinta doar o locatie vida care creaza o eticheta in linie.
Pentru a configura o eticheta in linie trebuie definita o clasa sau identificator care sa poata fi aplicat apoi unei etichete <span>. Iata un exemplu cu, forma generala, in care selectori sunt precedati de eticheta <span> :
…
<span class=”nume_clasa”> … </span>
…
<span id=”span1″> … </span>
…
<span class=”clasa_span”> … </span>
…
Acum iata cum pot fi definiti acestia in interiorul unei foi de stil:
.nume_clasa { proprietate1:valoare1; proprietate2:valoare2; … }
#span1 { proprietate1:valoare1; proprietate2:valoare2; … }
span .clasa_span { proprietate1:valoare1; proprietate2:valoare2; … }
In momentul in care se doreste configurarea unui bloc separat de restul continutului unui document HTML, solutia este eticheta <div>. Aceasta creaza o zona proprie in pagina, cu linie noua atat deasupra sa cat si dedesubtul sau.
Pentru crearea etichetelor DIV se procedeaza la fel ca si in cazul etichetelor in linie SPAN, prin definirea mai intai a unei etichete de tip clasa sau identificator, urmata apoi de aplicarea ei asupra unei etichete <div>.
Iata forma generala de aplicare a unei etichete <div> intr-o pagina HTML :
…
<div class=”nume_clasa”> … </div>
…
<div id=”div1″> … </div>
…
Definirea acestor etichete <div> intr-un cod CSS se face astfel:
div { proprietate1:valoare1; proprietate2:valoare2; … }
.nume_clasa { proprietate1:valoare1; proprietate2:valoare2; … }
#div1 { proprietate1:valoare1; proprietate2:valoare2; … }
Regulile CSS pentru definirea etichetelor <span> sau <div>, pot fi plasate la fel ca si celelalte tipuri de selectoare, in sectiunea „head” a documentului in interiorul etichetei „style”, sau intr-un fisier extern carev ulterior este legat sau importat in documentul HTML.
4. Definirea de reguli similare
Daca mai multi selectori folosesc aceleasi definitii css, acestia pot avea aceeasi lista de elemente, fiind scrisi separat prin virgule. Sintaxa generala pentru definirea unei liste cu mai multi selectori este urmatoarea:
- selector1, selector2, … { proprietate1:valoare1; proprietate2:valoare2; … }
Impreuna cu selectorii pot fi de asemenea definiti identificatorii si clasele. Dezavantajul ar fi ca in momentul in care este modificata o valoare a unei proprietati incluse in definitie, valoarea respectiva se va modifica in toate etichetele reprezentate de acesti selectori.
5. Definirea etichetelor in context (imbricate)
Cand o eticheta este inconjurata de alte etichete (aflandu-se astfel una in interiorul alteia), spunem ca aceste etichete sunt imbricate. Eticheta exterioara se numeste, in acest caz, eticheta parinte, iar cea inferioara se numeste copil. Se pot crea reguli care revin numai etichetelor copil, sintaxa generala a unei astfel de reguli fiind:
- selector1 selector2 … { proprietate1:valoare1; proprietate2:valoare2; … }
– Unde „selector1” este selectorul parinte iar „selector2” este selectorul copil.
Lista de selectori imbricati poate fi mai mare de doi, ultimul selector din lista este cel care primeste toate stilurile incluse in regula si in plus le mosteneste si pe cele ale parintilor.
Ca si selectorii singuri, selectorii imbricati pot include in lista clase, identificatori sau selectori HTML.
Toate etichetele HTML, cu exceptia etichetei BODY, au cel putin o eticheta parinte care le inconjoara. De cele mai multe ori stilurile etichetelor din interior preiau stilurile etichetelor parinte (exista insa cazuri in care proprietatile nu sunt mostenite de etichetele imbricate). Acest mecanism se numeste mostenirea stilurilor.
Prin redefinirea unui selector, eticheta nu-si pierde proprietatile prestabilite, doar in cazul in care acestea sunt modificate. Astfel proprietatile mostenite pot fi anulate prin redefinirea acestora in lista de definitii a etichetei imbricate.
6. Cresterea prioritatii unei definitii
Valoarea !important adaugata unei definitii atribuie maximum de prioritate in determinarea ordinii unei executii.
Valoarea !important trebuie plasata inaintea caracterului ’;’, ca in exempul urmator:
- selector { proprietate1:valoare1; proprietate2:valoare2 !important; … }
7. Determinarea ordinii executiei
Deoarece exista mai multe moduri de a aplica stilurile, pot apare situatii in care unei etichete sa-i fie aplicate mai multe stiluri. Foile de stil din doua sau mai multe surse, folosite simultan, pot cauza contradictii. De aceea exista cateva reguli care determina ordinea executiei (numita si cascada), acestea sunt:
- 1. Regulile CSS scrise in interiorul paginii HTML, in cadrul etichetei „style” din sectiunea „head” au o prioritate mai mare decat cele scrise intr-un fisier extern, iar regulile scrise in interiorul etichetelor au o prioritate mai mare decat cele din cadrul etichetei „style” din sectiunea „head”.
2. Existenta atributului !important – confera prioritate maxima la afisare definitiei in care este utilizat.
3. Sursa regulilor – exista numeroase navigatoare care permit utilizatorului sa-si defineasca propriile foi de stil. Totusi, foile de stil ale autorului le anuleaza pe cele ale vizitatorului daca acestea din urma nu au valoarea „!important”.
4. Specificitate – cu cat o regula dispune de mai multi selectori HTML, de clasa si de identificator, cu atat prioritatea ei creste. ID-urile au valoarea 100, clasele au valoarea 10, iar selectorii HTML au valoarea 1.
5. Momentul aparitiei – cu cat un stil apare mai tarziu, cu atat importanta lui este mai mare. Astfel, definitiile unei etichete copil au prioritatea mai mare si anuleaza toate stilurile precedente cu care intra in conflict.
8. Adaugarea comentariilor la CSS
Este bine ca uneori sa fie adaugate comentarii in codul CSS, mai ales in cazul fisierelor externe. Comentariile ajuta la intelegerea codului, facandu-se astfel cunoscut, pentru mai tarziu, rolu anumitor elemente din codul CSS.
Comentariile nu au nici un efect si pot fi plasate in jurul regulilor, fiind utile si in cazul navigatoarelor care nu suporta CSS.
Pentru a adauga comentarii in regulile de stil avem la dispozitie doua modalitati:
- In cazul in care comentariul se intinde pe un singur rand este suficienta folosirea perechii de caractere ’//’ urmata de comentariu.
- In cazul in care comentariul contine mai multe linie, trebuie plasat intre ’/*’ care deschide zona de comentariu si ’*/’ care indica sfarsitul comentariului.
In cazul folosirii comentariilor cu ’//’ se pot adauga oricate slash-uri, minimul fiind de doua.
Iata un exemplu in care puteti vedea cum pot fi adaugate comentariile:
/* Comentariu,
pe mai
multe linii */
.nume_clasa { proprietate1:valoare1; proprietate2:valoare2; … }
// Comentariu pe o singura linie
#div1 { proprietate1:valoare1; proprietate2:valoare2; … }
Configurarea fonturilor
Alegerea potrivita a fonturilor si folosirea acestora in cadrul paginilor web este importanta, poate atrage critici si comentarii din partea vizitatorilor, mai ales daca formatarea clasica prin scris normal, aldin sau cursiv nu este folosita corespunzator. CSS include facilitati de control asupra aspectului fonturilor, prin posibilitatea de a stabili familia de fonturi, atributele ingrosat si inclinat, dimensiunea literelor precum si spatiul dintre linii.
Exista cinci familii de fonturi de baza:
- serif – au un ornament (serif) plasat la terminatia literei, care ii ofera o distinctie speciala. Sunt folosite pentru tiparire, chiar daca textele sunt mai mari sau mai mici. Nu sunt indicate pentru afisarea textelor pe ecran.
- sans serif – sunt fonturi care nu folosesc serife, fiind indicate pentru continut text general.
- monospace – fonturile monospatiate pot avea serife, ele se deosebesc prin faptul ca fiecare litera ocupa aceeasi cantitate de spatiu. Sunt cele mai indicate pentru textele care trebuie citite cu exactitate, ca de exemplu liniile de program.
- cursive – imita scrisul de mana, intr-o maniera stilizata. Sunt indicate in scopuri decorative, nefiind recomandate pentru scrierea unor texte mai lungi.
- fantasy – nu se incadreaza in nici una dintre categoriile de mai sus, fiind fonturi care au un caracter predominant ornamental (reprezentand ilustratii sau pictograme).
1. Stabilirea fontului
Fontul folosit pentru afisarea unui text poate fi stabilit prin proprietatea „font”.
Pentru definirea fontului in cadrul unei reguli, trebuie specificata, dupa selectorul din cadrul foii de stil, proprietatea font-family urmata de numele fontului sau a fonturilor (despartite prin virgula). Este bine ca numele fonturilor sa fie incadrate intre ghilimele simple sau duble, mai ales daca numele acestora contine spatii.
Forma generala fiind urmatoarea:
- selector { font-family:”nume_font1″, „nume_font2”, …, nume_generic }
– Dupa ultima virgula se pot folosi urmatoarele nume generice de fonturi: „serif”, „sans-serif”, „cursive”, „monospace” sau „fantasy”. Includerea unei asemenea valori este optionala, insa recomandata.
Iata un exemplu practic:
h1 { font-family:”Arial”, „Helvetica”, sans-serif }
Cand este specificata o lista de fonturi, navigatorul incearca sa foloseasca primul font din lista, daca nu este gasit parcurge lista pana in momentul in care intalneste un font instalat. Daca nu exista fonturi echivalente, textul va fi afisat cu fontul prestabilit de browser. Daca este specificat un nume generic, textul va fi afisat cu un font apartinand aceluiasi stil, in cazul in care fonturile specificate in lista nu sunt disponibile.
Exista posibilitatea folosirii unei palete largi de fonturi in crearea paginilor web, nu doar a celor din lista limitata a fonturilor compatibile cu navigatoarele. Solutia consta in inglobarea fontului in cadrul paginii si trimiterea lui in mod automat in calculatorul vizitatorului, adica, descarcarea si folosirea lui automata.
Pentru a ingloba un font intr-o pagina si a-l descarca, se foloseste intructiunea @font-face. Aceasta trebuie sa includa proprietatea font-family, urmata de numele fontului si apoi trebuie indicata locatia pe server de unde poate fi descarcat fontul respectiv.
Codul CSS este urmatorul:
- @font-face { font-family:nume_font src: url(locatie_font); }
Nu poate fi ales orice font pentru a fi descarcat, acesta trebuie sa respecte un anume format. Totusi, problema este ca nu exista un format valabil pentru toate navigatoarele, de exemplu Internet Explorer foloseste fonturi in format „eof” (obtinute cu ajutorul unui program numit WEFT), iar Mozilla foloseste un format „otf”.
2. Stabilirea dimensiunii fontului
Cu ajutorul CSS se poate stabili dimensiunea fontului folosind valori absolute (exprimate in diferite unitati de masura: pixeli, centimetri), procentuale, sau chiar relative.
Pentru a defini dimensiunea fontului in cadrul unei reguli trebuie specificata proprietatea font-size urmata de o valoare a dimensiunii care poate lua una din urmatoarele tipuri de valori:
- – unitate de masura – exprimata in pixeli, puncte, inci sau centimetri
- – expresie absoluta – xx-small, x-small, small, medium, large, x-large si xx-large
- – expresiile smaller sau larger, ca raport cu elementul parinte
- – procent – un numar exprimat in procente (cu %), care indica marimea textului in raport cu dimensiunea elementului parinte
Iata forma generala a codului CSS pentru stabilirea dimensiunii fontului:
- selector { font-size:valoare }
Este bine ca pentru foile de stil care formateaza iesirea la imprimanta sa se foloseasca ca unitati de masura punctele, cm sau mm.
Pixelii reprezinta, probabil, cea mai des utilizata unitate de masura pentru stabilirea dimensiunii fontului. Pixelii nu reprezinta o masura foarte sigura, dar, de obicei, pentru afisarea pe ecran, constituie o masura mai sigura decat dimensiunea in puncte.
Iata un exemplu practic exprimat in pixeli:
h1 { font-size:15px; }
3. Text inclinat
Atributul „font-style” permite scrierea textelor inclinate in doua moduri: „cursiv” si „oblic”. Notiunile pot fi confundate, insa cursivul se refera la versiunea unui font a carui caractere au o inclinare spre dreapta, iar oblicul este un font inclinat fortat spre dreapta.
Pentru a crea caractere cursive in cadrul unei reguli trebuie precizata proprietatea font-style, astfel:
- selector { font-style:valoare }
Unde „valoare” poate fi unul din urmatoarele cuvinte: normal, italic sau oblique
Iata un exemplu:
h1 { font-style:italic; }
Valoarea normal se poate folosi pentru a sterge formatarea cu caractere inclinate atunci cand aceasta este mostenita.
4. Grosimea fontului
Ingrosarea este una dintre metodele utilizate des pentru scoaterea in evidenta a unui text. CSS confera mai multa flexibilitate in utilizarea textului ingrosat decat elementul HTML <b>, prin posibilitatea introducerii unei valori proprietatii font-weight, dupa cum urmeaza:
- bold – scrie fontul folosind caractere ingrosate
- bolder – mareste grosimea fontului relativ la grosimea curenta
- lighter – micsoreaza grosimea fontului fata de grosimea curenta
- – o valoare cuprinsa intre 100 si 900 (multiplu de 100) – reprezinta valoarea ingrosarii, bazata pe versiunile alternative disponibile ale fontului
- normal – elimina formatarea cu caractere aldine (ingrosate)
In cazul folosiri valorii cuprinse intre 100 si 900, 400 reprezinta valoarea corespunzatoare textului normal, iar 700 valoarea ingrosarii pentru stilul aldin. Majoritatea fonturilor nu dispun de noua ponderi, astfel ca daca este specificata o valoare care nu este disponibila, va fi folosita o alta pondere.
Forma generala pentru stabilirea grosimii fontului este urmatoarea:
- selector { font-weight:valoare }
Iata un exemplu practic:
h1 { font- weight:bold; }
5. Majuscule mici
Majusculele mici sunt folosite de obicei in cadrul titlurilor, ele fiind obtinute prin convertirea literelor mici in majuscule cu o dimensiune mai mica decat majusculelor normale. Astfel se obtin cuvinte in care toate literele sunt scrise cu majuscule insa prima litera este mai inalta decat celelalte.
Stabilirea unei reguli pentru majuscule mici se realizeaza prin utilizarea proprietatii font-variant cu valoarea small-caps. Prin folosirea valorii normal, vor fi anulate celelalte valori mostenite ale proprietatii font-variant.
Forma generala este urmatoarea:
- selector { font-variant:valoare }
Iata cum formatam un text dintr-o eticheta „h1” cu valoarea „small-caps”:
h1 {font-variant:small-caps;}
6. Valori multiple pentru font
Deseori este util sa fie precizate toate elementele fontului intr-o singura definitie.
Pentru a se realiza acest lucru este folosita proprietatea „font” urmata de valorile pentru celelalte proprietati, separate prin spatiu.
Sintaxa generala este urmatoarea:
- selector { font:val_font-family val_font-style val_font-variant val_font-weight val_font-size val_height }
Daca o anumita valoare din lista este omisa, navigatorul va folosi valoarea prestabilita.
Iata si un exemplu practic de folosire a mai multor valori in aceeasi definitie:
h1 { font:”Arial”,sans-serif italic small-caps bold 14pt; }
Configurarea textului
Textele alcatuiesc o buna parte din paginile web. Metodele de afisare a textelor prin controlul nu numai a fontului, dimensiunii si culorilor, ci si prin alte elemente, pot imbunatati aspectul pagini si pot atrage atentia asupra anumitor elemente din text.
1. Spatiul intre litere
Spatierea se refera la cantitatea de spatiu dintre literele unui cuvant. Se poate aduaga sau reduce spatiul dintre litere folosind proprietatea letter-spacing, urmata de o valoare exprimata intr-o anumita unitate de masura, ce poate lua si valori negative.
Sintaxa generala este urmatoarea:
- selector { letter-spacing:valoare }
Daca valoarea proprietatii este normal sau 0 atunci spatierea va fi fixata la valorile implicite (fara modificari suplimentare).
Daca se utilizeaza o valoare exprimata in em atunci dimensiunea rezultata va fi calculata in raport cu cea a elementului parinte.
Exemplu:
h1 { letter-spacing:1,5em; }
– Puteti folosi si pixeli (px)
2. Spatiul dintre cuvinte
CSS da posibilitatea modificarii spatiului intre cuvinte atat prin marire, cat si prin micsorare.
Spatiul dintre cuvinte poate fi modificat folosind proprietatea word-spacing, urmata de o valoare exprimata intr-o anumita unitate, fiind de obicei stabilita in pixeli.
Pentru anularea spatierii intre cuvinte, valoarea proprietatii trebuie sa fie: normal.
Sintaxa generala este urmatoarea:
- selector { word-spacing:valoare }
O valoare pozitiva semnifica un plus de spatiu adaugat la valoarea implicita, iar o valoare negativa reduce acest spatiu. Daca valoarea este egala cu 0 atunci spatiul dintre cuvinte este fixat la valoarea prestabilita, neproducand de fapt nici un efect, fiind similar cu valoarea normal.
Iata un exemplu in care marim spatiul intre cuvintele din eticheta „h2” cu 8 pixeli:
h2 { word-spacing:8px; }
3. Spatiul intre linii
Inaltimea randurilor se refera la spatiul dintre liniile paragrafului.
Modificarea spatiului intre linii poate avea ca efect o mai buna si usoara citire a textului in cazul in care aceasta este mai mare (creaza o regiune cu spatiu intre liniile de text). Alteori, daca inaltimea este mai mica (folosita la randurile de titlu), poate conferi un aspect mai stilat.
Pentru a modifiica inaltimea randurilor se foloseste proprietatea line-height, urmata de o valoare care poate fi exprimata in trei moduri:
- – un numar care inseamna multiplicarea dimensiunii fontului cu numarul respectiv pentru a obtine valoarea spatierii;
- – o valoare de tip absolut, exprimata in pixeli, puncte sau orice alta unitate de masura folosita in CSS, care indiferent de dimensiunea stabilita a fontului, inaltimea liniei va avea o valoare exacta;
- – un procent, care stabileste inaltimea liniei ca fiind egala cu un anumit procent din dimensiunea fontului folosit pentru scrierea textului.
Sintaxa generala pentru modificarea spatiului intre linii este:
- selector { line-height:valoare }
Iata un exemplu in care marim inaltimea liniei cu 50% din dimensiunea fontului:
h1 { line-height:150%; }
Inaltimea liniei poate de asemenea fi definita si in cadrul proprietatii „font-size”, prin introducerea caracterului „/” urmat de valoarea pentru inaltimea randului, imediat dupa dimensiunea fontului.
Exemplu:
h1 { font-size:12px/28px; }
4. Marimea (tipul) literelor
Exista cazuri in care se doreste afisarea textului cu un anume tip de litere. Folosind CSS, se poate specifica explicit ca textul sa apara cu majuscule initiale, majuscule, minuscule, combinat sau asa cum a fost el scris.
Cu ajutorul proprietatii text-transform se poate controla marimea literelor din text, indiferent de modul cum a fost el scris initial.
Pentru a schimba tipul literelor dintr-un text, proprietatea text-transform va fi urmata de o valoare care poate fi:
- capitalize – pentru ca primul caracter din fiecare cuvant sa fie scris cu majuscula;
- uppercase – pentru ca toate caracterele sa fie scrise cu majuscule;
- lowercase – pentru ca toate caracterele sa fie scrise cu litere mici;
- none – pentru ca textul sa fie afisat asa cum este.
Sintaxa generala este:
- selector { text-transform:valoare }
Iata un exemplu in care toate literele vor fi afisate cu majuscule:
h1 { text-transform:uppercase; }
Proprietatea „text-transform” este utila atunci cand textele sunt create in mod dinamic (de exemplu, in cazul in care ele provin dintr-o baza de date sau form HTML).
5. Alinierea textului
Un text poate fi aliniat de la marginea din stanga, din dreapta, centrat sau la ambele margini (stanga-dreapta).
Proprietatea text-align ofera posibilitatea controlului asupra alinierii textului.
Definirea alinierii se face specificand dupa proprietatea text-align una din valorile: left, right, centersau justify.
Forma generala este:
- selector { text-align:valoare }
Proprietatea poate fi aplicata numai elementelor la nivel de bloc (DIV, UL, Hx, p), valoarea sa implicita fiind in majoritatea cazurilor stabilita la valoarea „left”.
Iata un exemplu in care textul din eticheta „h2” este aliniat „stanga-dreapta”:
h2 { text-align:justify; }
– In cazul in care alinierea textului este „stanga-dreapta”, spatierea cuvintelor si a literelor se schimba pentru a se obtine linii de aceeasi lungime.
6. Alinierea pe verticala a textului
Cu ajutorul proprietatii vertical-align se poate preciza pozitia unor elemente (in linie) in raport cu textul din jurul lor. Asta inseamna ca proprietatea poate fi folosita doar cu etichete in linie care nu determina un salt la linie noua, de obicei utilizandu-se cu eticheta „span”.
Sintaxa pentru utilizarea proprietatii vertical-align este:
- selector { vertical-align:valoare }
Pentru definirea alinierii pe verticala a textului se foloseste una din urmatoarele optiuni:
- super – pentru scrierea textului in stil exponent, deasupra liniei de baza;
- sub – pentru scrierea textului in stil indice, sub linia de baza;
- baseline – pentru scrierea textului pe linia de baza;
- – una din valorile: „top”, „middle”, „bottom”, „text-top”, „text-bottom” – pentru a alinia textul relativ la alinierea parintelui acestuia;
- – valoare procentuala – care ridica sau coboara linia de baza a elementului proportional cu dimensiunea fontului elementului parinte.
Iata un exemplu in care textul din eticheta <span> va aparea ca exponent fata de textul din stanga-dreapta lui:
span { vertical-align:super; }
7. Formarea paragrafelor
Cu ajutorul proprietatii text-indent se poate stabili ce spatiu suplimentar este inserat la inceputul primei linii de text dintr-un paragraf. Pentru aceasta, proprietatea text-indent este urmata de o valoare exprimata intr-o unitate de masura (pixeli sau em) sau in procente (proportional cu latimea paragrafului).
Sintaxa generala este:
- selector { text-indent:valoare }
Valorile pozitive determina o indentare tipica (spre dreapta), in timp ce valorile negative determina o indentare inspre argine, fiind necesar sau marirea umplerii (padding) sau marirea marginilor.
Iata un exemplu de cod CSS in care va fi determinat un spatiu de 20 pixeli la inceputul paragrafului din eticheta <p>:
p { text-indent:20px; }
Daca se utilizeaza o valoare exprimata in unitati „em”, atunci rezultatul va fi relativ la dimensiunea fontului elementului asupra caruia se aplica. Pentru eliminarea decalarii se utilizeaza valoarea 0.
8. Aplicarea elementelor decorative
CSS permite ornarea textului prin scoaterea lui in evidenta in patru moduri: subliniere, supraliniere, taierea textului cu o linie sau crearea de texte care clipesc.
Aplicarea de elemente ornamentale unui text se realizeaza prin proprietatea text-decoration, urmata de una din valorile:
- underline – pentru a sublinia textul
- overline – pentru a trasa o linie deasupra textului
- line-through – pentru a taia textul cu o linie
- blink – pentru a face textul sa apara si dispara intermitent
Forma generala este :
- selector { text-decoration:valoare }
Pentru a elimina decoratiile se foloseste valoarea „none„. Prin folosirea acestei valori se elimina si sublinierile link-urilor, chiar daca navigatorul are prestabilit sa le arate subliniat.
Iata un exemplu de cod in urma caruia link-urile nu vor mai fi afisate subliniat:
a:link { text-decoration:none; }
Elementul decorativ „blink” a prezentat probleme, fiind de curand eliminat de unele navigatoarelor.
9. Spatiile albe
Intreruperile de linie si spatiile albe dintr-un document HTML sunt tratate ca un singur spatiu sau sunt ignorate, daca nu este utilizata eticheta <pre>.
CSS permite afisarea acestor spatii, precum si a intreruperilor textului, utilizand proprietatea white-space, urmata de valoarea „pre„.
Forma generala este:
- selector { white-space:valoare }
In locul cuvantului „valoare” poate fi adaugat: „pre”, „nowrap” sau „normal”
Utilizarea valorii „nowrap” impiedica trecerea la linia urmatoare.
Valoarea „normal” permite navigatorului sa decida asupra modului de tratare a spatiilor. De obicei, acestea vor fi transformate intr-un singur spatiu.
Iata un exemplu in urma caruia spatiile albe si trecerea la linia noua vor fi afisate asa cum au fost scrise:
p { white-space:pre; }
Spre deosebire de eticheta <pre> care schimba fontul cu unul monospatiat, valoarea „pre” a proprietatii white-space nu are nici un efect asupra fontului elementului la care se aplica.