Katika somo hili, utajifunza jinsi ya kutumia media queries kwa ajili ya kutengeneza tovuti zinazojibadilisha kulingana na ukubwa wa skrini. Tutazungumzia @media rules, breakpoints, na dhana ya mobile-first design.
Kwa sababu watu hutumia vifaa vya ukubwa tofauti kama simu, tablet, na kompyuta, tovuti inapaswa kuonekana vizuri kwenye kila kifaa. Hapa ndipo Responsive Design inapohusika, na nyenzo kuu ya kufanikisha hili ni CSS Media Queries.
@media Rules@media ni amri ya CSS inayoweka style fulani zitumike tu kwa hali maalum ya kifaa (screen).
Inaruhusu kuweka tofauti za muonekano kulingana na upana, urefu, orientation, resolution n.k.
@media (max-width: 768px) {
body {
background-color: lightblue;
}
}
💡 Maana yake: ikiwa upana wa skrini ni mdogo au sawa na 768px, badili rangi ya nyuma kuwa lightblue.
Breakpoints ni pointi maalum (kwa kipimo cha px) ambapo layout inabadilika ili kufaa kifaa tofauti.
🔸 Mfano wa Breakpoints ya kawaida:
| Kifaa | Upana (px) |
|---|---|
| Simu ndogo | max-width: 480px |
| Simu ya kawaida | max-width: 768px |
| Tablet | max-width: 1024px |
| Kompyuta ndogo | max-width: 1280px |
| Kompyuta kubwa | zaidi ya 1280px |
@media (max-width: 480px) {
.menu {
display: none;
}
}
@media (min-width: 769px) {
.menu {
display: block;
}
}
Mobile-first ni mbinu ya kwanza kubuni kwa simu, kisha kupanua kwa vifaa vikubwa.
Unaandika CSS ya msingi kwanza (kwa simu), kisha unaongeza style za vifaa vikubwa kwa kutumia min-width.
/* Styles za simu (default) */
.container {
padding: 10px;
font-size: 14px;
}
/* Styles kwa tablet na zaidi */
@media (min-width: 768px) {
.container {
padding: 30px;
font-size: 18px;
}
}
💡 Hii inaipa simu kipaumbele badala ya kuanza na desktop.
<div class="box">Karibu!</div>
.box {
background: green;
color: white;
padding: 20px;
text-align: center;
}
/* Kwa vifaa vidogo */
@media (max-width: 600px) {
.box {
background: orange;
}
}
/* Kwa vifaa vikubwa */
@media (min-width: 1024px) {
.box {
background: navy;
}
}
Media queries ni njia bora ya kufanya tovuti yako ionekane vizuri kwenye kila kifaa. Kwa kutumia @media, unaweza kudhibiti layout kulingana na ukubwa wa skrini na kuweka uzoefu mzuri kwa watumiaji wa simu, tablet, au desktop.
Tutajifunza jinsi ya kuleta miondoko na harakati kwenye tovuti kwa kutumia transition, transform, na animation.
@media (max-width: 768px) inamaanisha nini?
a) Styles zitatumika ikiwa skrini ni kubwa zaidi ya 768px
b) Styles zitatumika ikiwa skrini ni ndogo au sawa na 768px
c) Styles zitatumika kwa kompyuta pekee
d) Styles hazitafanya kazi
Nini maana ya breakpoint?
a) Kifaa kilichovunjika
b) Muda wa kuvunja layout
c) Kipimo cha skrini kinachobadili layout
d) Kifaa kinapopotea mtandaoni
Mobile-first design huanza na?
a) Kompyuta
b) Tablet
c) Simu
d) Smart TV
Ili style ifanye kazi tu kwenye kompyuta yenye skrini kubwa zaidi ya 1024px, utatumia?
a) @media (max-width: 1024px)
b) @media (min-width: 1024px)
c) @media screen
d) @media desktop-only
gap, flex, ::after ni sehemu za nini?
a) Media queries
b) HTML
c) CSS Layout tools
d) JavaScript
Umeionaje Makala hii.. ?
Katika somo hili, tutajifunza kuhusu CSS functions muhimu zinazotumika kufanya mahesabu, kuweka vipimo vya kisasa vinavyobadilika kulingana na hali ya kifaa, na kutumia variables. Tutazingatia functions kama: calc(), clamp(), var(), min(), max(), na mwishoni tutajifunza jinsi ya kutengeneza custom function kwa kutumia variables.
Soma Zaidi...Katika somo hili utakwenda kujifunza maana ya CSS, pia nitakujulisha kazi zake. Mwisho utatambuwa historia ya CSS toka kuanzishwa.
Soma Zaidi...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.
Soma Zaidi...Katika somo hili utajifunza kuhusu property muhimu ya CSS inayoitwa display, ambayo huamua jinsi element inavyoonyeshwa kwenye ukurasa. Tutachambua aina kuu za display: block, inline, inline-block, na none.
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...Katika somo hili utakwenda kujifunza sheria za uandish wa css yaani syntax za css
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, tutajifunza kipengele kipya kinachoitwa if() function ndani ya CSS, kilichoanza kupatikana kwenye toleo la Chrome 137. Kipengele hiki kinaturuhusu kuandika mantiki ya masharti moja kwa moja kwenye property ya CSS, bila kutumia JavaScript wala media query zilizotawanyika. Tutajifunza pia aina za queries: media(), supports(), na style() pamoja na matumizi yao ya kivitendo kwenye tovuti. Mwisho, tutaeleza kwa kina kuhusu pointer na any-pointer.
Soma Zaidi...Katika somo hili tutajifunza kuhusu CSS frameworks mbalimbali zinazosaidia kuharakisha uundaji wa mitindo kwenye tovuti. Tutazungumzia frameworks maarufu kama W3.CSS, Bootstrap, Google Fonts, na nyinginezo, faida, matumizi, na tofauti zao.
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...