picha

CSS - SOMO LA 26: CSS Specificity (Kipaumbele cha Styles)

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.

Utangulizi

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.


 


✅ 1. Uelewa wa Specificity

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.


✅ 2. Viwango vya Specificity

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

✅ 3. Mfano wa Specificity kwa Vitendo

<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.


✅ 4. Inline Styles na !important

<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.


✅ 5. Jinsi ya Kuepuka Migongano


Hitimisho

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.


? Maswali ya Kujitathmini

  1. Ni ipi kati ya zifuatazo ina specificity kubwa zaidi?
    a) .title
    b) h1
    c) #header
    d) *

  2. Specificity ya selector p.intro ni ngapi?
    a) 1
    b) 10
    c) 11
    d) 101

  3. Ni ipi hutumika kushinda specificity zote ikiwa imewekwa?
    a) .class
    b) #id
    c) style
    d) !important

  4. Selector div ul li a:hover ina specificity ya:
    a) 4
    b) 11
    c) 12
    d) 13

  5. 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

Jiunge nasi WhatsApp kupata update zetu
Zoezi la Maswali

Nyuma Endelea


Umeionaje Makala hii.. ?

       
Author: Rajabu image Tarehe: 2025-07-03 10:32:10 Topic: CSS Main: Masomo File: Download PDF Views 571

Share On:

Share follows: 0 | Unique share links followed: 0
Sponsored links
👉1 kitabu cha Simulizi     👉2 Madrasa kiganjani     👉3 Simulizi za Hadithi Audio     👉4 Kitabu cha Afya     👉5 Kitau cha Fiqh     👉6 Dua za Mitume na Manabii    

Post zinazofanana:

CSS - SOMO LA 16: Flexbox Basics

Katika somo hili, utajifunza msingi wa mfumo wa Flexbox unaotumika kupanga elementi kwa usahihi ndani ya kontena. Utajifunza kuhusu display: flex;, pamoja na properties muhimu kama justify-content, align-items, flex-direction, na gap.

Soma Zaidi...
CSS - SOMO LA 14: Position Property

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...
CSS - SOMO LA 19: Pseudo-classes na Pseudo-elements

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...
CSS - SOMO LA 25: CSS Shorthand Properties

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...
CSS - SOMO LA 10: Box Model katika CSS

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...
CSS - SOMO LA 8: Upambaji wa Maandishi (Text Styling)

Katika somo hili, utajifunza mbinu mbalimbali za kubadilisha muonekano wa maandishi kwa kutumia CSS, kama vile kupamba maandishi kwa mistari, kivuli, nafasi kati ya herufi, na mpangilio wa maneno.

Soma Zaidi...