|

Configurari pentru culori si fundal 2

Daca HTML permitea configurarea unor culori si elemente grafice de fundal doar pentru anumite elemente, CSS permite definirea culorii si a fundalului pentru orice element din pagina web.

1. Configurarea fundalului

Se poate schimba fundalul (background) intregii pagini, sau pentru un anumit element din pagina, fie el de tip DIV, paragraf, imagine, tabel sau formular.

a) Culoarea fundalului

Pentru a schimba culoarea fundalului se utilizeaza proprietatea background-color, urmata de o valoare care reprezinta numele culorii sau valoarea RGB, exprimata in cod hexa.
Sintaxa generala este:

  • selector {background-color:valoare }

Daca se foloseste valoarea „transparent” navigatorul va afisa culoarea prestabilita sau cea a elementului parinte.
Pentru schimbarea fundalului intregii pagini se aplica aceasta proprietate selectorului „body”.
Iata un exemplu in care culoarea de fundal a paginii este schimbata in albastru:

body { background-color:#0000ff; }


b) Imaginea de fundal

Puteti utiliza pentru fundal si o imagine, pentru aceasta se foloseste proprietatea background-image, urmata de adresa URL a locatiei imaginii.
Sintaxa generala este:

  • selector { background-image:url(‘adresa_URL’); }

Unde „adresa_URL” este calea si numele imaginii care va fi folosita
Daca in locul adresei URL se foloseste valoarea „none”, navigatorul nu va folosi nici o imagine.
Iata un exemplu in care pentru fundalul paginii este folosita o imagine:

body { background-image:url(‘cale/imagine.gif’); }


c) Repetarea imaginii de fundal

Pe langa posibilitatea afisarii unui element grafic ca fundal, CSS ofera si un mod de repetare a acestuia.
Pentru a repeta imaginea de fundal se foloseste proprietatea background-repeat, urmata de o valoare care poate avea una din urmatoarele optiuni:

  • repeat – pentru a repeta imaginea pe toata suprafata elementului respectiv;
  • repeat-x – pentru a repeta imaginea numai pe orizontala;
  • repeat-y – pentru a repeta imaginea numai pe verticala;
  • no-repeat – pentru a afisa imaginea o singura data, fara repetare.

Forma generala este:

  • selector { background-repeat:valoare }

Iata un exemplu de cod in care imaginea folosita pentru fundalul paginii se va repeta pe verticala pe toata inaltimea documentului:

body { background-repeat:repeat-y; }


d) Controlul imaginii de fundal

CSS poate defini modul de tratare a fundalului la derularea paginii, pentru aceasta se foloseste proprietatea background-attachment cu optiunea „fixed„, pentru a lipi imaginea de fundal de fereastra navigatorului sau optiunea „scroll„, pentru a permite derularea imaginii de fundal alaturi de elementul corespunzator atunci cand vizitatorul deruleaza pagina.
Sintaxa generala este:

  • selector { background-attachment:valoare }

Iata un exemplu practic aplicat imaginii folosita pentru fundalul paginii:

body { background-attachment:scroll; }


e) Pozitia imaginii de fundal

Pentru a pozitiona imaginii de fundal in functie de coltul din stanga-sus al elementului se utilizeaza proprietatea background-position urmata de doua valori (coordonate x si y) separate prin spatiu, ‘x’ pentru pozitia orizontala si ‘y’ pentru cea verticala.
Forma generala a acestei proprietati este:

  • selector { background-position:valoare }

Coordonatele x si y pot fi exprimate ca valori absolute sau ca procente. Se pot folosi si cuvintele cheie: „left„, „center” sau „right” pentru coordonata x; respectiv „top„, „center” sau „bottom” pentru coordonata y.
Iata un exemplu in care imaginea de fundal a paginii este pozitionata la 10 pixeli (x si y) relativ la coltul din stanga-sus:

body { background-position:10px 10px; }


f) Stabilirea simultana a proprietatilor fundalului

Toate proprietatile fundalului pot fi configurate cu ajutorul proprietatii background. Se poate stabili simultan printr-o lista de valori proprietatile fundalului, enumerate in orice ordine si separate prin spatiu.
Cand se utilizeaza proprietatea background, nu este necesar sa fie specificate toate proprietatile, cele nespecificate fiind stabilite la valoare lor implicita.
Sintaxa generala este:

  • selector {background:val_bg-color val_bg-img val_bg-repet val_bg-attach val_bg-position }

Valoarea implicita a proprietatii background-color este „transparent”.
Valoarea implicita a proprietatii background-image este „none”.
Valoarea implicita a proprietatii background-attachment este „scroll”.
Valoarea implicita a proprietatii background-position este „top left”.
Iata si un exemplu in care sunt aplicate mai multe proprietati pentru background, in aceeasi definitie:

div { background:#e8e8fe url(‘imagine.jpg’) 50% repeat }

– DIV-ul va avea culoarea de fndal „#e8e8fe”, cu o imagine pozitionata la jumatatea distantei X, Y si care se repeta.

2. Stabilirea culorii din prim-plan

Proprietatea color poate schimba culoare oricarui element, fie el text, linie orizontala sau element de tip formular.
Sintaxa generala pentru utilizarea acestei proprietati este:

  • selector { color:valoare }

Valoarea culorii poate fi:

  • numele culorii – una din cele 16 culori predefinite (red, green, blue, white, silver, …)
  • valoare in hexa – sub forma #rrggbb
  • valoare RGB – sub forma rgb(r, g, b), unde r, g, b pot fi reprezentate prin numere intregi cuprinse intre 0 si 255 sau procente de rosu, verde si albastru cu valori intre 0% si 100%.

Iata un exemplu de cod CSS in care culoarea textului din eticheta „h3” este definita verde:

h3 { color:green; }

Controale pentru chenare si afisarea elementelor

Indiferent daca o eticheta este de sine statatoare sau imbricata in alte etichete, aceasta poate fi tratata ca un element distinct pe ecran si poate fi controlata prin intermediul CSS.
Orice element creat intr-o foaie de stil este prezentat in propriul lui cadru.
Notiunea de element se refera la componentele unui document HTML, configurate prin intermediul etichetelor HTML.
Caseta (cadrul elementului) dispune de numeroase proprietati, intre care se numara: marginile, chenarul, completarea (umplerea, cunoscuta ca „padding”), latimea si inaltimea, care pot fi modificate cu ajutorul CSS.
Elementele HTML au patru laturi (sus, dreapta, jos si stanga) la care se pot aplica proprietatile CSS specifice, restul proprietatilor CSS (font, text, culoare, fundal) se aplica in continutului casetei. Continutul poate include texte, liste, formulare sau imagini.

1. Latimea si inaltimea unui element

Latimea si inaltimea elementelor pot fi specificate cu ajutorul proprietatilor width si height.
In mod prestabilit acestea sunt determinate automat de catre navigator, fiind egale cu necesarul afisarii intregului continut. Pentru definirea latimii si inaltimii se folosesc urmatoarele tipuri de valori:

  • – o valoare de tip numeric, de obicei in pixeli;
  • – un procent, care stabileste o valoare proportionala in functie de cea a elementului parinte;
  • – valoarea auto, care foloseste latimea si inaltimea calculata de navigator, si care reprezinta cantitatea de spatiu maxim pe care o poate ocupa elementul pentru afisarea intregului continut.

Sintaxa generala pentru configurarea latimii si inaltimii este:

  • selector { width:valoare; height:valoare }

Iata un exemplu in care elementul cu id=”un_id” va avea latimea de 300 pixeli si inaltimea de 500 pixeli:

#un_id { width:300px; height:500px; }

2. Marginile unui element

Proprietatea margin permite stabilirea distantei dintre un element si alte elemente alaturate, prin specificarea unei valor pentru marginea din fiecare latura (sus, dreapta, jos, stanga).
Daca specificati cele 4 valori in aceeasi definitie, acestea reprezinta marginile elementului in urmatoarea ordine: sus, dreapta, jos, stanga.
Daca specificati doar o valoare, aceasta va fi aplicata tuturor marginilor.
In cazu in care specificati doua sau trei valori, atunci valorile care lipsesc sunt copiate dupa valorile marginilor opuse.
Sintaxa generala pentru configurarea marginilor unui selector este:

  • selector { margin:valoare/valori; }

Tipul de valoare folosit poate avea urmatoarele optiuni:

  • – o valoare de tip lungime (numerica) – care poate fi si negativa;
  • – o valoare procentuala (procent) – creaza o margine proportionala cu latimea elementului parinte;
  • – valoarea auto – lasa controlul marginilor la decizia navigatorului.

Iata un exemplu in care etichetele DIV vor avea distanta pentru marginea de sus 10 pixeli, dreapta 5 pixeli, jos 8 pixeli si in stanga 15 pixeli:

div { margin:10px 5px 8px 15px; }


Exista posibilitatea de a stabili valoarea marginii doar pentru o singura latura, fara a tine cont de celelalte margini. Pentru aceasta sunt folosite proprietatile margin-top, margin-bottom, margin-left si margin-right cu aceleasi valori ca si in cazul proprietatii margin, dupa cum puteti vedea mai jos.

  • selector { margin-top:valoare; }
    selector { margin-bottom:valoare; }
    selector { margin-left:valoare; }
    selector { margin-right:valoare; }

3. Chenarul unui element

Proprietatea border permite stabilirea simultana a atributelor chenarului pentru toate cele patru laturi ale casetei. Aceasta foloseste 3 valori distincte, pentru a configura latimea (grosimea), stilul si culoarea liniei bordurii.
Sintaxa generala pentru definirea chenarului este:

  • selector { border:val_grosime val_stil val_culoare; }

Unde

  • – prima valoare (val_grosime) reprezinta grosimea chenarului si poate fi una din urmatoarele tipuri:
  •  
  • – o valoare de tip lungime (valoarea 0 determina anularea afisarii chenarului);
    – un cuvant cheie (thin, medium, thick) care caracterizeaza o dimensiune relativa.
  • – a doua valoare (val_stil) reprezinta numele stilului atribuit chenarului (valoarea „none” anuleaza afisarea chenarului);
  • – ultima valoare (val_culoare) reprezinta culoarea, exprimata in cod hexa sau valoare RGB.

Iata un exemplu in care div-urile vor avea o bordura groasa de 1 pixel, solid si culoare albastra:

div { border:1px solid blue; }


– Pot fi folosite si proprietati separate pentru fiecare: „border-width”, „border-style” si „border-color”; prezentate in continuare.

Un atribut care poate fi folosit in configurarea chenarului este border-width, acesta furnizeaza o metoda rapida pentru stabilirea latimii celor patru laturi din jurul unei casete.
Sintaxa generala este:

  • selector { border-width:valoare; }

Daca specificati toate cele patru valori, ele sunt aplicate in ordinea: sus, dreapta, jos, stanga.
Daca specificati doar o valoare, ea va fi aplicata tuturor marginilor.
Daca folositi doua sau trei valori, valorile care lipsesc sunt copiate din valorile marginilor opuse lor in caseta.

Aspectul bordurii poate fi stabilit prin atributul border-style; stilul este aplicat celor patru margini si este definit astfel:

  • selector { border-style:valoare; }

Pentru specificarea valorii, pot fi folosite urmatoarele tipuri:
CSS borders
Ultimele patru valori sunt reprezentate tridimensional, iar in cazul in care ele nu sunt acceptate de catre navigator, in locul lor se va folosi valoarea cu linie plina.

Un alt atribut care poate fi utilizat in configurarea chenarului este border-color, acesta stabileste culoarea pentru toate cele patru laturi ale chenarului si foloseste pentru valoarea ei un singur cuvant cheie exprimat in cod hexa, valoare RGB sau numele culorii.
Sintaxa generala este:

  • selector { border-color:valoare; }

Puteti stabili culoarea fiecarei margini si separat, folosind proprietatile:

  • border-top-color, border-right-color, border-bottom-color si border-left-color


Fiecare latura a chenarului poate avea valori configurate in mod separat (prin care se stabilesc stilul si culoarea fiecarei borduri din jurul elementului) dupa cum este prezentat mai jos:

  • selector { border-top:grosime stil culoare; }
    selector { border-bottom:grosime stil culoare; }
    selector { border-left:grosime stil culoare; }
    selector { border-right:grosime stil culoare; }

4. Adaugarea spatiului in interior, in jurul elementului

Proprietatea padding adauga o cantitate de spatiu suplimentar in jurul continutului elementului, in interiorul chenarului, intre bordura si continut.
Forma generala pentru utilizarea acestei proprietati este:

  • selector { padding: valoare/valori; }

Valoarea pentru completarea spatiului poate fi una din urmatoarele:

  • – o valoare de tip lungime
  • – o valoare procentuala – creaza umplerea in raport cu latimea elementului parinte.

Cand specificati toate cele patru valori, ele sunt aplicate in ordinea: sus, dreapta, jos, stanga.
Daca specificati doar o valoare, aceasta va fi aplicata tuturor celor patru directii.
Daca specificati doua sau trei valori, atunci valorile care lipsesc sunt copiate dupa valorile laturilor opuse.
Iata un exemplu in care etichetele DIV vor avea distanta padding: sus 4 pixeli, dreapta 2 pixeli, jos 3 pixeli si in stanga 2 pixeli:

div { padding:4px 2px 3px 2px; }


Fiecare latura a chenarului poate avea proprietatea padding configurata separat:

  • selector { padding-top:valoare; }
    selector { padding-bottom:valoare; }
    selector { padding-left:valoare; }
    selector { pading-right:valoare; }

5. Elemente float

CSS ofera posibilitatea de a „infasura” anumite elemente in jurul altora. Acest lucru se face prin intermediul proprietatii float, care determina o mutare fortata a elementului in directia data de valoarea mentionata, lasand loc liber in spatiul opus directiei, care va fi ocupat de urmatorul element din codul HTML.
Sintaxa generala pentru utilizarea acestei proprietati este:

  • selector { float:valoare; }

Unde „vaoare” poate fi” left, right si none
Valoarea „none” permite elementului sa fie plasat acolo unde este posibil, iar celelalte valori forteaza plasarea elementului in stanga sau in dreapta ecranului, textul din exteriorul etichetei HTML respective va fi plasat in partea opusa, in jurul elementului.
Iata un exemplu in care elementul cu id=”un_id” va fi fortat sa fie pozitionat in dreapta celorlaltor elemente:

#un_id { float:right; }

6. Anularea plasarii unui element in spatiul eliberat de „float”

Asemanator cu actiunea etichetei HTML <br>, care trece pe un nou rand elementele ce o preced, este si proprietatea clear.
Cu ajutorul acesteia se poate anula ocuparea unui spatiu care a fost lasat liber de un element care utilizeaza proprietatea „float”.
Sintaxa generala pentru utilizarea proprietati clear:

  • selector { clear:valoare; }

Unde „valoare” specifica latura in jurul careia este interzisa infasurarea textului si poate lua valoarea: left, right sau both. Se poate folosi si valoarea „none”, ceea ce are ca efect anularea altor atribute ale proprietatii clear.
De exemplu, daca aveti un DIV pozitionat fortat in dreapta, un paragraful care urmeaza dupa el va fi afisat in stanga DIV-ului respectiv. Pentru a anula acest lucru, ca paragraful sa fie afisat sub DIV, se foloseste proprietatea „clear”, precum in exemplul urmator:

#un_div { float:right; }
p { clear:both; }

7. Afisarea si ascunderea elementelor

Proprietatea display poate stabili daca un element va fi de tip block, incluzand linii noi deasupra si dedesubtul sau, daca este inclus in linie, daca este tratat sub forma de lista sau daca elementul este afisat sau nu.
Sintaxa generala pentru aceasta proprietate este:

  • selector { display:valoare; }

Unde „valoare” poate fi una din urmatoarele optiuni:

  • list-item – plaseaza in prima linie a textului un indicator pentru articole de tip lista, dar si un salt deasupra si dedesubtul articolului;
  • block – defineste eticheta ca fiind de tip bloc si plaseaza un salt la linie noua deasupra si dedesubtul ei;
  • inline – defineste eticheta ca o eticheta in linie si elimina caracterele de salt la linie noua;
  • none – determina ascunderea elementului si neafisarea lui de catre navigator; codul acestuia este incarcat insa continutul sau nu e afisat in pagina.

Iata un exemplu in care elementele <li> sunt asezate in linie, iar un element cu id=”un_id” va fi ascuns in pagina:

li { display:inline; }
#un_id { display:none; }

Proprietatea display nu trebuie confundata cu visibility. Spre deosebire de visibility care nu afiseaza elementul dar lasa liber spatiu pentru element, sintaxa display: none elimina complet elementul din pagina.

Controale de pozitionare

Pozitionarea elementelor folosind CSS este mai precisa decat prin intermediul obiectelor grafice HTML sau a tabelelor, afisarea facandu-se mult mai rapid.
Prin intermediul CSS este permisa pozitionarea exacta sau relativa a elementelor intr-o fereastra sau in raport cu alte elemente.
Fereastra navigatorului este suprafata in care sunt afisate toate elementele. Ea poate fi redimensionata sau pozitionata pe ecran, sau poate fi divizata in alte ferestre prin intermediul cadrelor.
Toatele elementele amplasate in fereastra sunt pozitionate relativ la coltul din stanga-sus.

1. Stabilirea modului de pozitionare

Prin utilizarea proprietatii position se poate specifica pozitia elementului in pagina web.
Un element poate avea una din urmatoarele valori de pozitionare: static, relative, absolut si fixed.
Tipul de pozitie indica navigatorului cum sa trateze amplasarea unui element intr-o fereastra.

a) Pozitionarea statica

Valoarea initiala, prestabilita, a pozitionarii elementelor in fereastra este „static”.
Cand nu este specificata o pozitionare „relativa”, „absoluta” sau „fixa”; elementele sunt dispuse unul dupa altul in interiorul documentului.
Sintaxa pentru specificarea pozitionarii static este:

  • selector { position:static }

– Un element static nu poate fi repozitionat in mod explicit.

b) Pozitionarea relativa

Un element cu pozitionare „relativa” este amplasat la locul sau in cadrul ferestrei sau a elementului parinte, in sensul ca el apare dupa toate elementele dinaintea sa, respectiv inaintea tuturor elementelor amplasate dupa el.
Sintaxa pentru specificarea pozitionarii relative este:

  • selector { position:relative }

– Elementele pozitionate relativ pot fi mutate din locatia lor folosind proprietatile „top” si „left” sau „bottom” si „right”.

c) Pozitionarea absoluta

Pozitionarea absoluta are ca efect crearea unui element neafectat de restul documentului, plasarea lui in fereastra fiind facuta intr-o locatie precisa, definita prin intermediul coordonatelor x si y, indiferent de pozitiile altor elemente.
Sintaxa pentru specificarea pozitionarii absolute este:

  • selector { position:absolute }

– Originea (punctul de coordonate 0,0) este coltul din stanga-sus al ferestrei sau al obiectului in care este inclus elementul pozitionat absolut.

d) Pozitionarea fixa

Pozitionarea fixa a unui element este aproximativ la fel cu cea absoluta, cu diferenta ca la derularea paginii elementul fixat ramane pe pozitia lui initiala, fara a se derula.
Sintaxa pentru specificarea pozitionarii fixed este:

  • selector { position:fixed }

2. Pozitionarea in raport cu latura de sus, respectiv stanga

Dupa stabilirea tipului de pozitionare, se poate determina distanta intre punctul de origine si laturile de sus si din stanga ale elementului sau parinte, folosind proprietatile top si left
Forma generala este:

  • selector { top:valoare; left:valoare; }

– Unde „valoare” poate fi:

  • – o valoare de tip numeric, care defineste distanta dintre laturile ferestrei sau a elementului parinte si laturile elementului;
  • – o valoare procentuala, care semnifica deplasarea fata de laturile ferestrei sau a elementului parinte;
  • – valoarea auto, care permite navigatorului sa calculeze el insusi valoarea.

Pot fi utilizate proprietatile top si left sau bottom si right, de asemenea pot lua si valori negative.
In cazul in care este vorba despre elemente imbricate, acestea vor fi deplasate solidar cu elementul parinte daca acesta are position:relative.
Iata un exemplu in care o eticheta <h1> este pozitionata la o distanta de 10 pixeli fata de marginile sus si stanga ale unui DIV in interiu caruia se afla:

<style type=”text/css”>
    div { position:relative; }
    h1 { top:10px; left:10px; }
</style>

<div>
    <h1>Text…</h1>
</div>

3. Pozitionarea in raport cu latura de jos, respectiv dreapta

In unele cazuri este necesara pozitionarea in raport cu laturile de jos, respectiv dreapta. In acest caz originea va fi coltul din dreapta-jos al ferestrei sau al elementului parinte.
Definirea marginilor fata de latura de jos, respectiv din dreapta se face cu ajutorul proprietatilor bottom si right; ele pot lua aceleasi valori ca si „left” si „top”, de asemenea pot fi combinate cu acestea.
Forma generala este:

  • selector { bottom:valoare; right:valoare; }

In cazul in care pentru acelasi element sunt stabilite atat marginile „top / left” cat si „bottom / right”, rezultatul afisat depinde de navigator, dar in mod prestabilit se folosesc pozitiile top si left.

4. Pozitionarea in spatiul 3D

Elementele pot primi o a treia dimensiune, si anume asezarea lor in stiva, unele in raport cu altele.
Amplasarea se face in mod automat, incepand cu valoarea 0 si continuand prin incrementare cu o unitate, in ordinea aparitiei lor in documentul HTML si relativ la elementele parinte.
Pentru pozitionarea elementelor in stiva unele peste altele se foloseste proprietatea z-index. Valoarea acestei proprietati fiind relatia tridimensionala a elementului in raport cu alte elemente din fereastra.
Sintaxa generala pentru proprietatea z-index este:

  • selector { z-index:valoare; }

Unde „valoare” este un numar intreg, pozitiv, 0 sau negativ.
In cazul in care continutul elementelor se suprapune, elementul cu numarul de ordine mai mare apare deasupra elementului cu numar mai mic.
Utilizarea unei valori negative determina amplasarea elementului dedesubtul parintelui sau cu atatea niveluri cu cate indica indexul z.

5. Includerea unui element absolut intr-un element relativ

Un element poate fi pozitionat exact in cadrul unei ferestre, sau el poate fi inclus intr-un element cu pozitionare relativa.
In cazul includerii unui element pozitionat absolut intr-un element pozitionat relativ, elementul absolut este pozitionat folosind ca origine coltul din stanga-sus al elementului relativ.
Iata un exemplu de cod HTML in care o eticheta <div> (cu class=”absolut”) este inclusa (imbricata) in alta eticheta <div> (cu class=”relativ”):

<div class=”relativ”>

      <div class=”absolut”> … </div>

</div>

Pentru a face o pozitionare absoluta a elementului inclus (care are class=”absolut”) in elementul parinte (care are class=”relativ”), caruia ii definim o pozitionare relativa; scriem in foaia de stil urmatorul cod:

.relativ {position:relative; top:30px; left:50px; }
.absolut {position:absolute; top:15px; left:0px; }

6. Includerea unui element relativ intr-un element absolut

Cand un element pozitionat absolut este inclus intr-un element pozitionat relativ, primul foloseste ca origine coltul din stanga-sus al parintelui.
In cazul in care un element pozitionat relativ este plasat in interiorul unui element pozitionat absolut, acesta se va deplasa o data cu elementul absolut.
Iata un exemplu de cod HTML in care o eticheta <div> (cu class=”relativ”) este inclusa (imbricata) in alta eticheta <div> (cu class=”absolut”):

<div class=”absolut”>

      <div class=”relativ”> … </div>

</div>

Pentru a face o pozitionare relativa a elementului inclus (care are class=”relativ”) in elementul parinte (care are class=”absolut”), caruia ii definim o pozitionare absoluta; adaugam in foaia de stil urmatorul cod:

.absolut {position:absolute; top:20px; left:25px; }
.relativ {position:relative; top:10px; left:5px; }

Configurari pentru vizibilitate si mouse

CSS ofera posibilitatea de a afisa sau ascunde unele elemente sau parti ale unor elemente.

1. Stabilirea vizibilitatii unui element

Proprietatea visibility poate controla faptul ca un element sa fie vizibil sau nu. Chiar daca elementul este invizibil, el va ocupa un spatiu liber in pagina, acolo unde ar fi trebuit sa fie afisat.
Sintaxa pentru folosirea acestei proprietati este urmatoarea:

  • selector { visibility:valoare }

Unde „valoare” poate fi:

  • hidden – ascunde elementul de la afisarea pe ecran;
  • visible – afiseaza elementul;
  • inherit – vizibilitatea elementului este mostenita de la elementul parinte.

Iata un exemplu in urma caruia textul din interiorul etichetei <h1> va fi invizibil:

h1 { visibility:hidden; }

Pentru a ascunde complet afisarea unui element in pagina, se poate utiliza formula display:none;

2. Stabilirea suprafetei vizibile a unui element

Definirea suprafetei vizibile a unui element stabileste portiunea din elementul respectiv care este vizibila in fereastra navigatorului. Restul continutului acelui element nu dispare, ci este invizibil pentru vizitator.
Pentru a defini forma regiunii vizibile se foloseste proprietatea clip cu valoarea rect (definita prin patru valori separate prin spatii si incadrate de paranteze rotunde)
Forma generala este:

  • selector {clip:rect(val1 val2 val3 val4); }

– Valorile construesc un patrulater, definesc distanta dintre coltul din stanga-sus al elementului si laturile de sus, dreapta, jos si stanga ale regiunii vizibile.
Iata un exemplu de cod CSS in care suprafata vizibila a unui element cu id=”viz” va fi cea incadrata de valorile atributului rect:

#viz { clip: rect(25 300 125 100); }

Daca se foloseste valoarea „auto”, navigatorul calculeaza dimensiunea regiunii vizibile la 100%. Regiunile de vizibilitate pot avea doar forma dreptunghiulara.

3. Definirea pozitiei depasirii

Uneori elementele nu sunt in totalitate continute in casetele lor, caseta nefiind suficient de mare, astfel ca o parte a continutului nu este afisata sau depaseste marginea stabilita.
Proprietatea overflow permite tratarea continutului in exces, controland astfel modul de afisare sau nu al acesuia.
Forma generala a proprietatii overflow este:

  • selector { overflow:valoare; }

– Unde „valoare” stabileste unde va fi plasata depasirea, folosind una din valorile:

  • visible – extinde caseta elementului astfel incat sa incapa tot continutul sau, ignorand delimitarea suprafetei vizibile. Este optiunea prestabilita.
  • hidden – ascunde continutul care nu incape in caseta elementului, si impiedica aparitia barei de derulare.
  • scroll – adauga intotdeauna bare de derulare elementului, pentru ca sa se poata accesa tot continutul elementului.
  • auto – barele de derulare apar doar atunci cand este necesar.

Iata un exemplu in care toate elementele cu class=”extradim” vor avea bare de scroll:

.extradim { overflow:scroll; }


Pentru definirea proprietatii „overflow” doar pentru una din directii: orizontala sau verticala; adica bara de derulare sa fie disponibila sau nu doar pentru una din aceste directii, se poate folosi o alta varianta a acestei proprietati, si anume:

  • overflow-x:valoare – pentru orizontala
  • overflow-y:valoare – pentru verticala

– Unde „valoare” poate fi una din valorile prezentate mai sus.

4. Aspectul indicatorului de mouse

In mod normal, aspectul indicatorului de mouse este determinat de browser. Navigatorul modifica indicatorul de mouse in functie de continutul deasupra caruia se afla acesta.
Uneori este dorita anularea sau completarea preferintelor navigatorului si configurarea unor aspecte personalizate.
Proprietatea cursor ajuta la stabilirea aspectului unui indicator de mouse.
Sintaxa este urmatoarea:

  • selector { cursor:valoare; }

Unde „valoare” poate avea urmatoarele nume pentru indicatoarele de mouse:
Indicatoare de mouse

– Daca se foloseste valorea „auto”, navigatorul decide asupra tipului de indicator folosit.

Pseudo-clase

Pseudo-clasele permit adaugarea de stiluri CSS doar la anumite elemente ale aceluiasi selector, id sau clasa.
De exemplu, cand definiti un stil pentru un anumit tag HTML sau pentru o clasa, continutul din toate aceleasi tag-uri sau aceeasi clasa vor avea acel stil, iar daca doriti sa definiti un stil diferit pentru primul (sau ultimul) din acele tag-uri ori pentru primul continut definit de aceeasi clasa, puteti realiza asta folosind pseudo-clasele. De asemenea, acestea pot modifica stilul grafic al elementelor cand mouse-ul actioneaza asupra lor.
Pentru a functiona in Internet Explorer 7+ este necesar declararea <!DOCTYPE>, care se adauga la inceputul documentului HTML, mai multe detalii (in engleza) gasiti Aici.
Sintaxa pentru utilizarea pseudo-clasei este urmatoarea:


                element:pseudo-clasa { proprietate:valoare; }


– unde „element” este un selector, id sau clasa, iar „pseudo-clasa” este una din expresiile urmatoare:

  • active   – Adauga un stil unui element cand acesta este activat (actionat prin click pe el)
  • first-child   – Adauga un stil unui element care este primul din acel tip de elemente
  • focus   – Folosit pentru input-urile de formulare, le adauga un stil cand acestea sunt active (dupa click si cursorul de text in ele)
  • hover   – Adauga un stil unui element cand mouse-ul se afla deasupra lui
  • lang(cuvant)   – Adauga un stil unui element care are atributul lang=”cuvant” (nu e suportat de Safari si IE mai mic de 8)
  • last-child   – Adauga un stil unui element care este ultimul din acel tip de elemente
  • link   – Adauga un stil unui link nevizitat
  • visited   – Adauga un stil unui link vizitat


Ca sa intelegeti mai bine cum functioneaza si ce fac pseudo-clasele, studiati exemplele care sunt prezentate in continuare.

1. Pseudo-clase cu selector

Selectoarele fac referire la tag-urile HTML pe care le denumesc (de ex.: p pentru <p>, li pentru <li>, div pentru <div>, etc.).
In exemplul urmator este folosit „first-child” pentru paragraf:

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-clase – Ex. 1</title>
<style type=”text/css”>
p:first-child {
    color:blue;
}
</style>
</head>
<body>
<p>Un text din primul paragraf</p>
<p>Continut din al doilea paragraf</p>
<p>Textul din al treilea paragraf</p>
</body>
</html>

– Rezultatul va fi urmatorul, primul paragraf va avea textul albastru.

Un text din primul paragraf

Continut din al doilea paragraf

Textul din al treilea paragraf


Iata si un exemplu cu „hover” pentru <li>

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-clase – Ex. 2</title>
<style type=”text/css”>
li:hover {
    background-color:#88fe88;
}
</style>
</head>
<body>
<ul>
  <li>Text list 1 …</li>
  <li>Text list 2 …</li>
  <li>Text list 3 …</li>
</ul>
</body>
</html>

– Cand pozitionati mouse-ul deasupra fiecarui LI, acesta va avea background verde, testati mai jos

  • Text list 1 …
  • Text list 2 …
  • Text list 3 …

2. Pseudo-clase si clase

Trebuie stiut ca pseudo-clasele nu sunt acelasi lucru ca si clasele, acestea fiind cele care fac referire la valoarea atributului „class” si in CSS se adauga dupa un caracter punct (.).
Iata un exemplu in care sunt folosite pseudo-clasele „lang(cuvant)” (pt. IE incepand cu versiunea 8) sl „last-child” la o clasa „.test’

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-clase – Ex. 3</title>
<style type=”text/css”>
.test:last-child {
    background-color:#88fe88;
}

.test:lang(da) {
    color:blue;
}
</style>
</head>
<body>
<ul>
  <li class=”test”>Text in list cu class 1 …</li>
  <li class=”test” lang=”da”>Text in list cu class 2 …</li>
  <li class=”test”>Text in list cu class 3 …</li>
</ul>
</body>
</html>

– Observati ca stilul definit pentru „.test:last-child” va fi aplicat doar ultimului element care are clasa „test”, iar „lang(da)” se aplica numai elementului care pe langa class=”test” are si lang=”da”.
– Rezultatul este acesta:

  • Text in list cu class 1 …
  • Text in list cu class 2 …
  • Text in list cu class 3 …


Iata un alt exemplu in care sunt combinate o clasa (test), un selector (tag <i>) si „first-child”:

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-clase – Ex. 4</title>
<style type=”text/css”>
.test i:first-child {
    font-weight:bold
}
</style>
</head>
<body>
<p class=”test”><i>Paragraf</i> cu mai multe tag-uri I: <i>text oblic</i>, alt test <i>oblic</i></p>
<p class=”test”>Alt paragraf: <i>sir inclinat si bold</i>, alt sir <i>italic</i></p>
</body>
</html>

– Stilul CSS va fi aplicat primelor tag-uri <i> din fiecare clasa „.test”, dupa cu puteti vedea mai jos

Paragraf cu mai multe tag-uri I: text oblic, alt test oblic

Alt paragraf: sir inclinat si bold, alt sir italic

– Daca doriti ca stilul sa fie aplicat tuturor etichetelor <i> din prima clasa, scrieti:   .clasa:first-child i
– Daca vreti sa fie aplicat numai primului <i> din prima clasa, scrieti:   .clasa:first-child i:first-child

3. Pseudo-clase cu id-uri si elemente de formular

In CSS, id-urile fac referire la valoarea atributului ID si se scriu dupa caracterul #.
Iata un exemplu in care este folosita pseudo-clasa „hover” impreuna cu un ID, iar „focus” impreuna cu o clasa (focus nu functioneaza pe versiuni de IE mai mici de 8)

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-clase – Ex. 5</title>
<style type=”text/css”>
#unid:hover {
    background-color:#dadafe;
}

.test:focus {
    background-color:#ededfe;
}
</style>
</head>
<body>
<form action=”” method=”post”>
  <input type=”text” class=”test” /><br />
  <textarea cols=”20″ rows=”5″ class=”test”></textarea><br />
  <input type=”button” value=”Buton” id=”unid” />
</form>
</body>
</html>

– Stilul CSS definit in acest exemplu face ca atunci cand mouse-ul se afla deasupra butonului (care are id=”unid”) acesta sa isi schimbe culoarea de fundal, iar cand se da click pe zonele de text din formular (care au class=”test”), la fel se modifica culoarea background.
– Rezultatul este urmatorul formular.

Top of Form

Pseudo-elemente

Pseudo-elementele permit adaugarea de stiluri CSS anumitor parti din continutul unui element HTML.
De exemplu, cand definiti un stil pentru un anumit tag HTML (sau pentru o clasa), tot continutul incadrat de acel tag va avea acelasi stil, iar daca vreti sa adaugati un stil CSS diferit primei litere sau primului rand dintr-un paragraf, se folosesc pseudo-elemente.
Sintaxa pentru utilizarea pseudo-elementelor este urmatoarea:
                obiect_css:pseudo-element { proprietate:valoare; }
– unde „obiect_css” este un selector, id sau clasa, iar „pseudo-element” este una din expresiile urmatoare:

  • after   – Adauga continut dupa un element HTML (nu e suportat de versiuni IE mai mici de 8)
  • before   – Adauga continut inaintea unui element HTML (nu e suportat de versiuni IE mai mici de 8)
  • first-letter   – Adauga un stil css primului caracter dintr-un text
  • first-line   – Adauga un stil primei linii dintr-un text


Ca sa intelegeti mai bine cum functioneaza si ce fac pseudo-elementele, iata cateva exemple cu fiecare in parte.

1. after

Pentru a adauga un anumit continut (text, imagine, sunet .wav) prin CSS, se foloseste proprietatea content si valoarea ce reprezinta continutul respectiv: text se adauga intre ghilimele, iar imagine sau sunet .wav se adauga folosind ca valoare url(adresa_fisier)
In urmatorul exemplu va fi adaugat un continut text dupa fiecare element <h4>.

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-elemente – Ex. 1</title>
<style type=”text/css”>
h4:after {
    content:”CursCSS”;
    color:blue;
}
</style>
</head>
<body>
<h4>Continutul din primul tag H4 … </h4>
<h4>Un alt text din alt element H4</h4>
</body>
</html>

– Rezultatul va fi cel de jos.
– Observati cum este adaugat cuvantul „CursCSS”, imediat dupa ultimul caracter al fiecarui element <h4>, ca si cum ar face parte din textul initial, dar putand avea stil propriu.

Continutul din primul tag H4 … CursCSS

Un alt text din alt element H4CursCSS

– In loc de selector puteti folosi si ID sau clasa.

2. before

Before este similar cu „after”, continutul se adauga la fel, dar la inceputul elementului.
Pentru o mai mare difersitate, puteti combina pseudo-clasele cu pseudo-elemente folosind sintaxa:
                obiect_css:pseudo-clasa:pseudo-element { proprietate:valoare; }
Pseudo-clasele sunt explicate in lectia anterioara.
Ca sa vedeti efectul, iata un exemplu aplicat cu „before” acelorasi tag-uri H4 din exemplul precedent.

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-elemente – Ex. 2</title>
<style type=”text/css”>
h4:first-child:before {
    content:”CursCSS- „;
    color:blue;
}
</style>
</head>
<body>
<h4>Continutul din primul tag H4 … </h4>
<h4>Un alt text din alt element H4</h4>
</body>
</html>

– De data aceasta continutul „CursCSS- ” este adaugat imediat in fata si doar primului element <h4> (precizat prin ‘first-child’), dupa cum puteti vedea mai jos:

CursCSS- Continutul din primul tag H4 …

Un alt text din alt element H4

– Daca vreti sa adaugati in loc de continut text o imagine, de exemplu .gif, scrieti codul CSS astfel:   h4:first-child:before { content:url(imagine.gif); }

3. first-letter

First-letter aplica un stil CSS doar primului caracter dintr-un text.
In urmatorul exemplu este aplicat un stil CSS primului caracter din continutul fiecarui element definit printr-o clasa „test”.

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-elemente – Ex. 3</title>
<style type=”text/css”>
.test:first-letter {
    font-size:25px;
    color:red;
}
</style>
</head>
<body>
<p class=”test”>Textul din paragraf …</p>
<div class=”test”>Alt continut int-un tag DIV, dar cu aceeasi clasa.</div>
</body>
</html>

– Dupa cum puteti vedea in rezultatul de mai jos, prima litera din continutul fiecarui tag ce are class=”test” este de culoare rosie si marime 25px.

Textul din paragraf …

Alt continut int-un tag DIV, dar cu aceeasi clasa.

4. first-line

First-line aplica un stil CSS doar primei linii din continutul elementului HTML.
Studiati exemplul urmator:

<!DOCTYPE html PUBLIC „-//W3C//DTD XHTML 1.0 Transitional//EN”
„http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html>
<head>
<title>Pseudo-elemente – Ex. 4</title>
<style type=”text/css”>
.test:first-line {
    font-weight:bold;
    color:blue;
}
</style>
</head>
<body>
<p class=”test”>Paragraf cu mai multe linii<br />
  A doua linie …<br />
  Alta linie din acelasi paragraf.</p>
<div class=”test”>Continut pe doua linii intr-un tag DIV<br />
  A doua linie din DIV.</div>
</body>
</html>

– Rezultatul este urmatorul, comform codului CSS, prima linie din fiecare element cu class=”test” are textul albastru si ingrosat.

Paragraf cu mai multe linii
A doua linie …
Alta linie din acelasi paragraf.

Continut pe doua linii intr-un tag DIV
A doua linie din DIV.

Similar Posts

Lasă un răspuns

Adresa ta de email nu va fi publicată. Câmpurile obligatorii sunt marcate cu *