Katika somo hili, tutajifunza kuhusu CSS Specificity — yaani mfumo wa kipaumbele unaotumiwa na kivinjari kuchagua ni mtindo (style) upi utumike iwapo kuna migongano kati ya selectors mbalimbali. Utaelewa jinsi ya kupanga selectors zako vizuri ili kuzuia matatizo ya mitindo kutofanya kazi kama ulivyotarajia.
Katika CSS, wakati ambapo selector zaidi ya moja inalenga elementi ile ile, kivinjari huchagua mtindo mmoja tu wa kutumia. Ili kufanya hivyo, hutegemea mfumo unaoitwa specificity — ambao ni mfumo wa alama unaoamua ni mtindo gani una nguvu zaidi.
Mfano: Kama selector #header na .title zote zinaweka rangi ya maandishi tofauti kwenye <h1 class="title" id="header">, basi kivinjari kitaweka ile yenye specificity kubwa zaidi.
Specificity ni kipimo cha "nguvu" ya CSS selector. Selector yenye nguvu zaidi (specificity kubwa) hushinda zingine zinazolenga elementi hiyo hiyo.
CSS Specificity huhesabiwa kwa mfumo wa pointi kwa aina mbalimbali za selectors.
| Selector | Pointi/Uzito wa Specificity |
|---|---|
Inline styles (style="") |
1000 |
ID selectors (#id) |
100 |
Class, pseudo-class (.class, :hover) |
10 |
Element selectors (div, p) |
1 |
Universal selector (*) |
0 |
<h1 class="title" id="header">Habari</h1>
CSS:
h1 { color: blue; } /* Specificity = 1 */
.title { color: green; } /* Specificity = 10 */
#header { color: red; } /* Specificity = 100 */
Matokeo:
Rangi ya h1 itakuwa nyekundu, kwa sababu #header ina specificity kubwa zaidi.
<h1 id="main" style="color: orange;">Karibu</h1>
Inline style inakuwa na specificity ya 1000 — hivyo hushinda zote.
Pia, ikiwa utatumia !important, hiyo ina nguvu ya kipekee na hushinda hata selector yoyote:
.title {
color: blue !important;
}
Lakini tumia !important kwa tahadhari — ni vizuri kutumia specificity ya kawaida ili kuweka msimamizi bora wa CSS zako.
Tumia selectors zenye uhusiano mzuri: epuka kutumia id nyingi bila sababu.
Andika CSS kwa mfumo wa ndani nje: mfano, nav ul li a inaeleweka vizuri kuliko #menuItem.
Epuka kutumia !important ovyo.
Tumia specificity calculator (kama ile ya w3schools au CSS Tricks) kusaidia kuhesabu.
Specificity ni sehemu muhimu ya CSS ambayo kila mbunifu wa tovuti anatakiwa kuelewa. Ikiwa hautazingatia specificity, unaweza kuona mitindo yako haitumiki jinsi ulivyotarajia. Kwa kuielewa, utaweza kusuluhisha migongano ya CSS kwa haraka na kwa ustadi.
Ni ipi kati ya zifuatazo ina specificity kubwa zaidi?
a) .title
b) h1
c) #header
d) *
Specificity ya selector p.intro ni ngapi?
a) 1
b) 10
c) 11
d) 101
Ni ipi hutumika kushinda specificity zote ikiwa imewekwa?
a) .class
b) #id
c) style
d) !important
Selector div ul li a:hover ina specificity ya:
a) 4
b) 11
c) 12
d) 13
Ni ipi kati ya hizi ni njia bora ya kuepuka migongano ya specificity?
a) Kutumia id mara nyingi
b) Kutumia !important kila sehemu
c) Kufuatilia mfumo wa selectors wa ndani kwenda nje
d) Kutumia universal selector
Umeionaje Makala hii.. ?
Katika somo hili utakwenda kujifunza sheria za uandish wa css yaani syntax za css
Soma Zaidi...Katika somo hili utajifunza kuhusu property ya position katika CSS, ambayo hutumika kuamua jinsi element inavyowekwa ndani ya ukurasa. Tutajifunza aina tano kuu za position: static, relative, absolute, fixed, na sticky.
Soma Zaidi...Katika somo hili utajifunza tofauti kati ya margin na padding, kazi ya kila moja, jinsi ya kuzipima, na jinsi zinavyotumika kudhibiti nafasi ndani na nje ya elementi kwenye ukurasa wa HTML.
Soma Zaidi...Katika somo hili, utajifunza kuhusu pseudo-classes kama :hover, :first-child, na :last-child, pamoja na pseudo-elements kama ::before, ::after, na ::selection. Hizi husaidia kubadili au kuongeza mitindo maalum kulingana na hali ya elementi au sehemu maalum ya elementi.
Soma Zaidi...Somo hili linakuletea ufahamu wa kina juu ya CSS Transitions na Animations, likifafanua vipengele vyake muhimu, matumizi, na namna ya kutumia properties mbalimbali za animation kwa ufanisi katika kurahisisha muonekano na mtumiaji wa tovuti.
Soma Zaidi...katika somo hili utajifunza jinsi ya ku install css kwenye ukurasa wa html
Soma Zaidi...Katika somo hili utajifunza jinsi ya kudhibiti mwonekano wa maandishi kwa kutumia fonti kwenye CSS. Utajifunza jinsi ya kubadilisha aina ya fonti, ukubwa, mtindo, unene, na mpangilio wa maandishi ili yaweze kuonekana kwa mvuto na usomaji bora.
Soma Zaidi...Katika somo hili, utajifunza jinsi ya kudhibiti muonekano wa sehemu ya nyuma (background) ya HTML element kwa kutumia CSS. Utaweza kuongeza rangi, picha, kuweka picha zisirudiwarudiwe, na hata kusogeza picha kwenye maeneo tofauti ya ukurasa.
Soma Zaidi...Katika somo hili utajifunza muundo wa boksi (Box Model) katika CSS. Box model ni mfumo wa msingi wa kupanga vipengele katika ukurasa wa HTML, ukiwa na sehemu kuu nne: content, padding, border, na margin.
Soma Zaidi...Katika somo hili tutajifunza kwa kina kuhusu CSS Shorthand Properties — ni nini, jinsi zinavyofanya kazi, faida zake, na mifano mbalimbali ya kutumia shorthand kuandika CSS kwa njia fupi na bora zaidi.
Soma Zaidi...