စိုင္းသီဟစိုး ဆိုက္မွအားလံုးကို လိႈက္လွဲေႏြးေထြးစြာနဲ႕ႀကိဳဆိုပါတယ္။ ကၽြန္ေတာ္ဆိုက္ကို လာေရာက္သူအားလံုး ကိုယ္စိတ္ႏွစ္ပါး က်န္းမာခ်မ္းသာပါေစလို႕ ဆုမြန္ေကာင္းေတာင္းေပးလိုက္ပါတယ္.....
စိုင္းသီဟစိုး ဆိုက္မွအားလံုးကို လိႈက္လွဲေႏြးေထြးစြာနဲ႕ႀကိဳဆိုပါတယ္။ ကၽြန္ေတာ္ဆိုက္ကို လာေရာက္သူအားလံုး ကိုယ္စိတ္ႏွစ္ပါး က်န္းမာခ်မ္းသာပါေစလို႕ ဆုမြန္ေကာင္းေတာင္းေပးလိုက္ပါတယ္.....
စိုင္းသီဟစိုး ဆိုက္မွအားလံုးကို လိႈက္လွဲေႏြးေထြးစြာနဲ႕ႀကိဳဆိုပါတယ္။ ကၽြန္ေတာ္ဆိုက္ကို လာေရာက္သူအားလံုး ကိုယ္စိတ္ႏွစ္ပါး က်န္းမာခ်မ္းသာပါေစလို႕ ဆုမြန္ေကာင္းေတာင္းေပးလိုက္ပါတယ္.....
စိုင္းသီဟစိုး ဆိုက္မွအားလံုးကို လိႈက္လွဲေႏြးေထြးစြာနဲ႕ႀကိဳဆိုပါတယ္။ ကၽြန္ေတာ္ဆိုက္ကို လာေရာက္သူအားလံုး ကိုယ္စိတ္ႏွစ္ပါး က်န္းမာခ်မ္းသာပါေစလို႕ ဆုမြန္ေကာင္းေတာင္းေပးလိုက္ပါတယ္.....
စိုင္းသီဟစိုး ဆိုက္မွအားလံုးကို လိႈက္လွဲေႏြးေထြးစြာနဲ႕ႀကိဳဆိုပါတယ္။ ကၽြန္ေတာ္ဆိုက္ကို လာေရာက္သူအားလံုး ကိုယ္စိတ္ႏွစ္ပါး က်န္းမာခ်မ္းသာပါေစလို႕ ဆုမြန္ေကာင္းေတာင္းေပးလိုက္ပါတယ္.....

Saturday, December 15, 2012

CSS for starter
Intro
CSS ဆိုတာကေတာ့ Web Essential ပိုင္းမွာ မသိမျဖစ္ လိုအပ္ပါတယ္။ Web ပိုင္းမွာ HTML
တစ္ခုတည္းတတ္ေနရံုနဲ႕ မရပါဘူး။ HTML က သင့္ site တစ္ခုလံုးကို လွသြားေအာင္
ေဆာက္ရြက္ေပးႏိုင္မွာမဟုတ္ဘူး။ CSS ကို HTML တတ္ျပီးတဲ့သူတိုင္း အလြယ္တကူ
ေလ့လာႏုိင္ပါတယ္။ ကၽြန္ေတာ္တုိ႕ေတြ Internet website ေတြမွာ ျမင္ေနရတဲ့ site ေတြ
အားလံုးဟာ CSS ကို အသံုးျပဳထားပါတယ္။ HTML နဲ႕ တည္ေဆာက္ျပီး လွပေအာင္
တန္ဆာဆင္ဖို႕ CSS ကို ေလ့လာထားဖို႕လိုအပ္ပါတယ္။
ကၽြန္ေတာ့္အေနနဲ႕လည္း ဘယ္လိုေရးရလဲဆိုတဲ့ အေျခခံနဲ႕ ဘာေတြ ရိွတယ္။ ဘာေတြ
သံုးလို႕ရလဲဆိုေတာ့ ကိုပဲ ရွင္းျပေပးႏိုင္ပါတယ္။ CSS ဟာက်ယ္ျပန္႕ျပီးေတာ့ ကိုယ့္
အေတြးအေခၚ ကိုယ့္ design ေပၚမွာ မူတည္ျပီး site ရဲ႕ design ကလည္း ေျပာင္းလဲသြားတာပါ။
အခု စာအုပ္က w3school ကို အေျခခံျပီး ေရးသားထားပါတယ္။ စတင္ေလ့လာမယ့္သူေတြ
အတြက္ အသံုးဝင္မယ့္ စာအုပ္ တစ္အုပ္ ျဖစ္မယ္လို႕လည္း ေမွ်ာ္လင့္ပါတယ္ဗ်ာ။
CSS for starter , written by saturngod ( www.saturngod.net )
1
Chapter 1: CSS Basic
CSS Syntax (CSS = Cascading Style Sheet )
CSS ကို ေရးသားပံုက HTML နဲ႕ မတူေတာ့ ပဲ ေရးသားပံုေတြ ကြာျခားသြားပါတယ္။ css code
ေလးကို ၾကည့္ရေအာင္။
Selector ကေတာ့ ကိုယ္ ဘာဟာကို CSS အသံုးျပဳမလဲဆိုတာကို ေျပာတာပါ။ အခု h1 ဆိုတဲ့
tag ကို select လုပ္ထားလိုက္တာပါ။ Declaration က တစ္ခုထက္ ပိုထည့္ႏိုင္ပါတယ္။ တစ္ခု
ဆံုးတိုင္း ; ေလး ထည့္ေပးရပါတယ္။ Property နဲ႕Value ရိွပါတယ္။ ကၽြန္ေတာ္တုိ႕ HTML
မွာတုန္းက attribute နဲ႕ value ထည့္သလိုေပါ့။ property နဲ႕ value ကို : ေလး ခံျပီး
ထည့္ပါတယ္။
color:blue; font-size:12px;
ဆိုတဲ့ သေဘာက စာလံုးအေျပာေရာင္ စာလံုးအရြယ္ 12 px လို႕ဆိုလိုက္တာပါ။
ဥပမာ။ ေအာက္က code ေလးကို notepad မွာ ေရးျပီး စမ္းၾကည့္လုိက္ပါ။
<html>
<head>
<title>CSS</title>
<style type="text/css">
p { color: red;}
</style>
</head>
<p>Hi! I am red.</p>
CSS for starter , written by saturngod ( www.saturngod.net )
2
</html>
အဲဒါေလးကို save သိမ္းျပီး firefox နဲ႕ ဖြင့္လိုက္ရင္ ေအာက္ကပံုလို ျမင္ရပါလိမ့္မယ္။
CSS ေရးမယ္ဆိုရင္ <style> နဲ႕ စျပီး </style> နဲ႕ ဆံုးတဲ့ ၾကားထဲမွာ ေရးရပါတယ္။
အမ်ားအားျဖင့္ေတာ့ <head> နဲ႕ </head> ၾကားထဲမွာ ေရးရပါတယ္။
Comment
HTML မွာတုန္းကလည္း comment လုပ္ပံုေျပာခဲ့ပါတယ္။ HTML comment ဆုိရင္ <!--
comment --> နဲ႕ေရးခဲ့တာ မွတ္မိအံုးမယ္ထင္ပါတယ္။ CSS မွာလည္း comment
ေရးလို႕ရပါတယ္။ သူကိုေတာ့ ဒီလိုေရးပါတယ္။
/* This is comment */
/* နဲ႕ စျပီး */ ဆံုး ပါတယ္။ ၾကားထဲမွာ comment ေရးရတာပါ။
Selector
အေပၚမွာ ကၽြန္ေတာ္ ေျပာခဲ့ဘူးပါတယ္။ Selector အေၾကာင္းပါ။ Select မွာ HTML element
ေတြ ျဖစ္တဲ့ p , h3 စတာေတြ သံုးလို႕ရသလို id နဲ႕class ကိုလည္း သံုးလို႕ရပါတယ္။ HTML
attribute မွာ id နဲ႕class ဆိုတာ ရိွပါတယ္။
ID Selector
ကၽြန္ေတာ္တုိ႕ html attribute id ဆိုတာကို ထည့္ျပီး အဲဒါကို css မွာ တြဲသံုးႏုိင္ပါတယ္။
ဥပမာကို ေအာက္က code ကို ေလ့လာၾကည့္လုိ္က္ပါ။
<html>
<head>
<title>CSS</title>
CSS for starter , written by saturngod ( www.saturngod.net )
3
<style type="text/css">
#red_id { color: red;}
</style>
</head>
<p id="red_id">Hi! I am red id.</p>
<p >Hi! I am normal.</p>
</html>
အဲဒါေလးကို browser နဲ႕ဖြင့္ လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
id မွာ red_id ဆိုျပီးေရးထားပါတယ္။ အဲဒါကို ျပန္ေခၚဖို႕ CSS မွာ #red_id
နဲ႕ျပန္ေခၚထားတာကို ေတြ႕မွာပါ။ အရင္တုန္းကေတာ့ p ဆိုတဲ့ html tag ကို ေခၚခဲ့ေပမယ့္ အခု
တစ္ခုထဲကို သီးသန္႕ေခၚခ်င္ေတာ့ id ေပးျပီး ေခၚလိုက္တာပါ။
Class Selector
id လိုပဲ HTML attribute တစ္ခုျဖစ္တဲ့ class ဆိုတာကို သံုးႏိုင္ပါတယ္။ id ကေတာ့
အမ်ားအားျဖင့္ တစ္ခုတည္းကို နာမည္သေဘာမ်ဳိး identify သေဘာမ်ဳိးနဲ႕ေပးတတ္ၾကျပီး class
ကေတာ့ အမ်ားကို ကိုယ္စားျပဳတဲ့အေနနဲ႕ေပးပါတယ္။ class ကိုလည္း id လိုမ်ဳိးပဲ
အသံုးျပဳႏိုင္ပါတယ္။ ေအာက္က code ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<title>CSS</title>
<style type="text/css">
.red_class { color: red;}
</style>
</head>
<p class="red_class">Hi! I am red class.</p>
<p> Hi! I am normal.</p>
CSS for starter , written by saturngod ( www.saturngod.net )
4
<p class="red_class">Hi! I am red class.</p>
</html>
အဲဒါဆိုရင္ Hi! I am red class ဆိုတဲ့ စာလံုးေတြက နီေနတာကို ေတြ႕မွာပါ။ ဒါေလးကိုေတာ့
ကိုယ္တိုင္ စမ္းၾကည့္ႏိုင္ပါတယ္။ ပံုေလးေတာ့ မျပေတာ့ဘူး။ အတူတူပဲမို႕ပါ။ class ကို dot(.)
ေရွ႕မွာ ထားျပီး ေရးပါတယ္။ class ကို ေနာက္တစ္မ်ဳိးေရးလို႕ရပါတယ္။ ဥပမာ p tag မွာ
သံုးထားတဲ့ class ဆိုရင္
p.red_class { color: red;}
ဆိုျပီး ေရးလို႕ရပါတယ္။ h3 မွာ သံုးထားရင္
h3.red_class { color: red;}
ဆိုျပီးေရးလိုက္ရံုပါပဲ။ ေအာက္က code ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<title>CSS</title>
<style type="text/css">
h3.red_class { color: red;}
</style>
</head>
<h3 class="red_class">Hi I am H3</h3>
<p class="red_class">Hi! I am red id.</p>
<p> Hi! I am normal.</p>
<p class="red_class">Hi! I am red id.</p>
</html>
အဲဒါကို ဒီလိုေလး ထြက္လာမွာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
5
p မွာ red_class လို႕ထည့္ထားေပမယ့္ css မွာ h3.red_class လို႕ေရးထားပါတယ္။ red_class
လို႕ ေၾကျငာထားတဲ့ h3 ကိုပဲ select လုပ္မယ္လို႕ ဆိုလိုတာပါ။
How to add CSS ?
အေပၚမွာတုန္းက ကၽြန္ေတာ္ ေျပာခဲ့ပါတယ္။ CSS ဘယ္လို ထည့္သြင္းရမယ္ဆိုတာကိုေပါ့။
<head> နဲ႕ </head> ၾကားမွာ style tag နဲ႕ ထည့္တယ္လို႕။ အဲဒါအျပင္ အျခား ၂
နည္းရိွပါေသးတယ္။ စုစုေပါင္း ၃ မ်ဳိးထည့္သြင္းလုိ႕ရပါတယ္။
1. Internal Style Sheet
2. Inline Stye Sheet
3. External Style Sheet
Internal Style Sheet
ကၽြန္ေတာ္တုိ႕ internal Style Sheet အေၾကာင္းေျပာခဲ့ျပီးပါျပီ။ အေပၚမွာ သံုးခဲ့တာေတြ
အားလံုးက Internal style sheet သေဘာတရားေတြပါ။
Inline Style Sheet
ကၽြန္ေတာ္တုိ႕ေတြအေနနဲ႕ တစ္ခါတစ္ေလမွာ style sheet တစ္ခုတည္းကို html tag
ထဲတြဲသံုးခ်င္တဲ့အခါမွာ သံုးလို႕ရေအာင္ပါ။သူ႕ကို ဒီလိုေရးပါတယ္။
<p style="color:red"> Hi! I am red.</p>
CSS for starter , written by saturngod ( www.saturngod.net )
6
အဲဒါဆိုရင္ Hi! I am red က အနီေရာင္ေလး ျဖစ္သြားတာကို ေတြ႕မွာပါ။
ကၽြန္ေတာ္တုိ႕ေတြအေနနဲ႕ အခ်ဳိ႕အခါေတြမွာ class တုိ႕ id တို႕ မေၾကျငာပဲ ေရးခ်င္တဲ့အခါေတြ
မွာ အသံုးျပဳႏုိင္ပါတယ္။
External Style Sheet
Internal Style Sheet က page တစ္ခုတည္းအတြက္ အဆင္ေျပေပမယ့္ page ေတြက
တစ္ခုထက္မက သံုးမယ္။ ဒီ style ပဲ သံုးမယ္ဆိုရင္ Internal Style Sheet က
အဆင္မေျပေတာ့ပါဘူး။ HTML အသစ္ တစ္ခုေဆာက္တိုင္း copy paste လုိက္လုပ္ရမယ္။
တစ္ေနရာမွာ ေျပာင္းလိုက္တိုင္း HTML files အားလံုးမွာ လုိက္ေျပာင္းရမယ္။ အဲလို အခါ
အဆင္မေျပေတာ့ဘူး။ ဒါေၾကာင့္ HTML files ေတြ တစ္ခုထက္ မက သံုးမယ္ဆိုရင္ External
Style Sheet ကိုသံုးႏုိင္ပါတယ္။ External Style Sheet ကို ေခၚမယ္ဆိုရင္ ေအာက္ကလို
ေခၚသံုးပါတယ္။
<head>
<link rel="stylesheet" type="text/css" href="external.css">
</head>
external.css ကေတာ့ သီးသန္႕ file ပါ။ file path ေတြကိုေတာ့ HTML တုန္းက ေျပာခဲ့ျပီးပါျပီ။
image path ေတြ ေခၚတဲ့ေနရာမွာတုန္းက ရွင္းျပခဲ့ပါတယ္။ external.css ကိုလည္း အဲလို
ေခၚတာပါပဲ။
external.css ထဲမွာေတာ့ ဒီလိုေရးထားပါတယ္။
.red_class { color: red;}
တစ္ျခား ဘာမွ မပါပဲ css ေတြ ခ်ေရးထားရံုပါပဲ။ တျခား html tag ေတြ ထည့္စရာလည္း
မလုိပါဘူး။
အခု အေျခခံအခ်က္ေတြနားလည္ျပီဆိုရင္ေတာ့ CSS styling အေၾကာင္းေတြ
စျပီးေလ့လာလို႕ရပါျပီ။ property က color တစ္ခုတည္း မဟုတ္ပဲနဲ႕ အျခား property
အေၾကာင္းေတြကို ေနာက္ chapter မွာ စပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
7
Chapter 2: CSS Styling
CSS မွာ property က အမ်ားၾကီးရိွပါတယ္။ အရင္ chapter တုန္းကေတာ့ color property နဲ႕ပဲ
ဥပမာ ျပသြားပါတယ္။
CSS Background
Background ကို မေျပာခင္ background နဲ႕ လုပ္ထားတဲ့ CSS ေလးကို ျပပါတယ္။
အဲဒါက CSS background image နဲ႕ CSS backround color ကို သံုးထားတာပါ။ သာမာန္
HTML နဲ႕ အဲလိုမ်ဳိး ဖန္တီးလို႕ မရပါဘူး။
Background Color
Background color က ေနာက္ခံ အေရာင္ပါ။ ေအာက္က code ေလးကို
စမ္းၾကည့္လုိက္ရေအာင္။
<html>
<head>
<title>Back ground</title>
<style type="text/css">
body {background-color:#b0c4de;}
</style>
</head>
<body>
CSS for starter , written by saturngod ( www.saturngod.net )
8
</body>
</html>
အဲဒါေလးကို run လုိက္ရင္ ခရမ္းေရာင္ background ကို ျမင္ရမွာပါ။
Color ေတြကိုေတာ့ ေအာက္ကပံုစံေတြနဲ႕ သံုးလို႕ရပါတယ္။
1. name :: color နာမည္နဲ႕ ေခၚယူသံုးစြဲျခင္း။ ဥပမာ ။။ red, blue
2. RGB :: RGB value အေနနဲ႕ ေခၚယူသံုးစြဲျခင္း။ ဥပမာ ။။ rgb(255,0,0)
3. Hex :: hex value အေနနဲ႕ အသံုးျပဳျခင္း။ ဥပမာ ။။ #FF0000
4. RGBA :: RGB နဲ႕ အတူတူပါပဲ။ သို႕ေပမယ့္ ေနာက္မွာ Alpha channel value ပါလာပါတယ္။
ဥပမာ ။။ rgba(255,0,0,0.5)
Color ကိုေတာ့ အေသးစိတ္မေျပာေတာ့ပါဘူး။ ကၽြန္ေတာ္ HTML မွာတုန္းက
ေသခ်ာေျပာခဲ့ျပီးပါျပီ။ ေအာက္က example ေလးကို စမ္းၾကည့္ရေအာင္။
<html>
<head>
<title>Back ground</title>
<style type="text/css">
h1 {background-color:#6495ed;}
p {background-color:#e0ffff;}
div {background-color:#b0c4de;}
</style>
</head>
<body>
<h1>Header</h1>
<div>
This is DIV Layer using background-color.
<br/>
<p>This is paragraph using background-color.</p>
</div>
</body>
</html>
အဲဒါေလးကို ဒီလုိေလး ျမင္ရမွာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
9
ဒီေလာက္ဆိုရင္ေတာ့ background-color ကို သေဘာေပါက္ေလာက္ပါျပီ။
Background Image
Background Image ကေတာ့ ပံုေတြ မွာ background ထည့္တာေပါ့။
ဒီပံုေလးကေတာ့ paper.gif ပါ။
<html>
<head>
<style type="text/css">
body {background-image:url('paper.gif');}
</style>
</head>
<body>
<h1>Hello World!</h1>
</body>
</html>
အဲဒီ code ေလးကို browser မွာ ဖြင့္လိုက္ရင္ ဒီလိုျမင္ရပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
10
background တစ္ခုလံုး paper.gif ေတြ ျပည့္သြားတာကို ျမင္ရမွာပါ။ ပံုတစ္ပံုတည္းကို tile
လုပ္သြားတာပါ။ တနည္းေျပာရင္ pattern လိုမ်ဳိး တစ္ကြက္ျပီး တစ္ကြက္
အျပည့္ျဖည့္သြားတာေပါ့။ ဒါေၾကာင့္ wallpaper ေတြကို background ထည့္လိုက္ရင္ Title
ျဖစ္သြားျပီး ၾကည့္မေကာင္းျဖစ္တတ္တယ္။
Background Image - Repeat Horizontally or Vertically
ကၽြန္ေတာ္တုိ႕ေတြ background image ကို repeat horinonal ပဲလုပ္ခ်င္တယ္။ ဒါမွမဟုတ္
vertical ပဲလုပ္ခ်င္တယ္ဆုိရင္လည္း လုပ္လုိ႕ရပါတယ္။
အဲလို gradient လုပ္ထားတဲ့ ပံုကို background image နဲ႕သံုးလိုက္ရင္ ေအာက္ကလို
ျဖစ္သြားပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
11
သူက horizontal fill သြးာတာ ျပႆနာ မဟုတ္ေပမယ့္ vertical ျဖည့္သြားေတာ့ ၾကည့္ရ
ဆိုးသြားပါတယ္။ vertical မျဖည့္ဘူး။ horizontal ပဲ လုပ္မယ္ဆိုရင္ ဒီလိုေရးရပါတယ္။
<html>
<head>
<style type="text/css">
body
{
background-image:url('gradient2.png');
background-repeat:repeat-x;
}
</style>
</head>
<body>
<h1>Hello World!</h1>
</body>
CSS for starter , written by saturngod ( www.saturngod.net )
12
</html>
အဲဒါေလးကို run လိုက္ရင္ ဒီလို ရပါလိမ့္မယ္။
အဲဒါဆိုရင္ ၾကည့္လို႕ေကာင္းသြားပါျပီ။ repeat-x ဆိုတဲ့အတြက္ေၾကာင့္ horizontal ပဲrepeat
လုပ္ပါမယ္။ တကယ္လုိ႕ repeat-y လို႕သာ ေရးခဲ့မယ္ဆိုရင္ေတာ့ vertical ပဲ repeat လုပ္မွာပါ။
repeat-y ကိုေတာ့ ဥပမာ နဲ႕ မျပေတာ့ပါဘူး။ ကိုယ္တိုင္သာ စမ္းၾကည့္လိုက္ပါ။
Background Image : Set Position
အရင္ဆံုး ဒီ code ေလးကို run ၾကည့္လုိက္ပါ။
<html>
CSS for starter , written by saturngod ( www.saturngod.net )
13
<head>
<style type="text/css">
body
{
background-image:url('img_tree.png');
background-repeat:no-repeat;
}
</style>
</head>
<body>
<h1>Hello World!</h1>
<p>W3Schools background image example.</p>
<p>The background image is only showing once, but it is disturbing
the reader!</p>
</body>
</html>
သိျပီးသားေနမွာပါ။ image_tree.png ကိုေတာ့ မိမိ စက္ထဲမွာ ရိွတဲ့ ပံုထဲက
အဆင္ေျပတာေလးနဲ႕ သံုးလုိက္ပါ။အဲဒါက ေအာက္ပါအတိုင္း ျမင္ရမွာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
14
ပံုက background မွာရိွေနပါတယ္။ ဘယ္ဘက္ ေထာင့္မွာ ကပ္ေနတာပါ။
ကၽြန္ေတာ္တုိ႕ ညာဘက္ေထာင့္ကို ပံုကပ္မယ္။ ေနာက္ျပီး စာကလည္း ပံုကို မဖုံးခ်င္ဘူး။ ပံုရဲ႕
width က 200px ရိွတယ္။ ဒါဆိုရင္ ဒီလိုေရးလိုက္ပါတယ္။
<style type="text/css">
body
{
background-image:url('img_tree.png');
background-repeat:no-repeat;
background-position:top right;
margin-right:200px;
}
</style>
</head>
CSS for starter , written by saturngod ( www.saturngod.net )
15
အဲမွာ margin-right:200px ဆိုတာက ညာဘက္ margin 200px ထိ ဆြဲထားလိုက္တာပါ။
margin ပိုင္း ေနာက္ပိုင္းမွာ ေျပာျပပါမယ္။ background-position:top right; ကို ၾကည့္ပါ။
top right ျဖစ္ေနပါတယ္။ top ကေတာ့ အေပၚဆံုးမွာထားမယ္ေပါ့။ ကၽြန္ေတာ္တုိ႕ ညာဘက္
ကပ္ခ်င္ေတာ့ right လို႕ေရးလိုက္ပါတယ္။
Background - Shorthand property
ကၽြန္ေတာ္တုိ႕ တစ္ခုျခင္းဆီ လုိက္မေရးျခင္ဘူး။ တစ္ေၾကာင္းတည္းနဲ႕ မျပီးဘူးလား။
ကၽြန္ေတာ္တုိ႕ေတြ တစ္ေၾကာင္းတည္းနဲ႕ background css ကို ေရးလို႕ရပါတယ္။ ဥပမာ။။
body {background:#ffffff url('img_tree.png') no-repeat top right;}
လို႕ေရးထားတာ အေပၚက code နဲ႕ အတူတူပါပဲ။ background ဆိုတဲ့ property မွာ ေအာက္က
property ေတြေပါင္းျပီး ေရးလို႕ရပါတယ္။
• background-color
• background-image
• background-repeat
• background-attachment
CSS for starter , written by saturngod ( www.saturngod.net )
16
• background-position
Background - background attchment
ကၽြန္ေတာ္ background-attchment အေၾကာင္း မေျပာခဲ့ရေသးပါဘူး။ background
attachment မလုပ္ခင္ ေအာက္က code ေလးကို စမ္းၾကည့္ပါအံုး။
<html>
<head>
<style type="text/css">
body
{
background-image:url('smiley.gif');
background-repeat:no-repeat;
}
</style>
</head>
<body>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
<p>The background-image is fixed. Try to scroll down the page.</p>
</body>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
17
အဲမွာ ကၽြန္ေတာ္တို႕စာကို ဆြဲခ်လိုက္ရင္ background image ေလး ေပ်ာက္သြားပါလိမ့္မယ္။
background image မေပ်ာက္ခ်င္ဘူး။ fixed ျဖစ္ေနေစခ်င္တယ္ဆိုရင္ ေအာက္ကလို
ေျပာင္းေရးလိုက္ပါ။
<style type="text/css">
body
{
background-image:url('smiley.gif');
background-repeat:no-repeat;
background-attachment:fixed;
}
</style>
ဒီ code ေလးကိုေတာ့ ကိုယ္တိုင္ စမ္းၾကည့္လုိက္ပါ။
All CSS background properties
Property Description Values
background background
အားလံုးအတြက္
သံုးႏိုင္သည္။
background-color
background-image
background-repeat
backgroundattachment
background-position
inherit
backgroundattachment
background image
fix လုပ္မလား scrolls
လုပ္မလား အတြက္
scroll
fixed
inherit
background-color background color
ထည့္သြင္းရန္
color-rgb
color-hex
color-name
transparent
inherit
background-image image background
တြင္ ထည့္သြင္းရန္
url(URL)
none
inherit
CSS for starter , written by saturngod ( www.saturngod.net )
18
Property Description Values
background-position background image
position ကို ခ်ိန္ညိွရန္
left top
left center
left bottom
right top
right center
right bottom
center top
center center
center bottom
x% y%
xpos ypos
inherit
background-repeat image မ်ားကို repeat
ဘယ္လို
လုပ္မည္အတြက္။
repeat
repeat-x
repeat-y
no-repeat
inherit
CSS for starter , written by saturngod ( www.saturngod.net )
19
CSS Text Formatting
Text formatting ဆိုတာကေတာ့ စာလံုးေတြကို အေရာင္ထည့္တာေတြ ေနာက္ျပီး font
ေတြေျပာင္းတာ alignment လုပ္တာ စတာေတြကို css ကို ေဆာင္ရြက္လို႕ရပါတယ္။
Text Color
text color ကိုေတာ့ CSS မွာ color လို႕သံုးပါတယ္။ ေအာက္မွာ ဥပမာ ၾကည့္ပါ။
body { color:#FF0000; }
လို႕ဆိုရင္ body စာလံုးေတြက အနီေရာင္နဲ႕ ျပေပးမွာပါ။
Text alignment
text alignment ကေတာ့ left, right , center,justify ဆိုျပီး သတ္မွတ္ေပးတာပါ။
ကၽြန္ေတာ္တို႕ html မွာက align နဲ႕ လုပ္ခဲ့တာ မွတ္မိအံုးမယ္ထင္ပါတယ္။ CSS မွာကေတာ့
p { text-align: center; }
h1 { text-align: right; }
h2 { text-align : justify }
left ကေတာ့ default ပါ။ ဒါေလးေတြက လြယ္ေသးေတာ့ ကိုယ့္ဘာသာ
ကိုယ္စမ္းၾကည့္လိုက္ပါ။
Text Transformation
ကၽြန္ေတာ္တုိ႕ေတြ HTML မွာ upper case ေတြ lower case ေတြေျပာင္းခ်င္ရင္ စာေတြ
ျပန္ျပင္ရိုက္ရပါတယ္။ CSS သံုးရင္ အဲလို ျပန္ျပင္ရိုက္တဲ့ ျပႆနာ ရွင္းသြားပါတယ္။ ေအာက္က
example ေလး ကို ၾကည့္ၾကည့္ပါ။
<html>
<head>
<title>Sample</title>
<style type="text/css">
CSS for starter , written by saturngod ( www.saturngod.net )
20
p.uppercase {text-transform:uppercase;}
p.lowercase {text-transform:lowercase;}
p.capitalize {text-transform:capitalize;}
</style>
<body>
<p class="uppercase">uppder case</p>
<p class="lowercase">LOWER CASE</p>
<p class="capitalize">capitalize</p>
</body>
</head>
</html>
အဲဒါေလး ကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
Text Indentation
စာလံုးေတြကိုေရႊ႕ခ်င္တယ္ဆိုရင္ indentation ကို သံုးလို႕ရပါတယ္။ ေအာက္က ဥပမာေလး
ကိုၾကည့္ၾကည့္ပါ။
<html>
<head>
<title>Sample</title>
<style type="text/css">
p {text-indent:50px;}
</style>
<body>
<p>
Testing Testing Testing Testing Testing Testing Testing Testing
Testing Testing Testing Testing Testing Testing Testing Testing
CSS for starter , written by saturngod ( www.saturngod.net )
21
Testing Testing Testing Testing Testing Testing Testing Testing
Testing Testing Testing Testing
</p>
</body>
</head>
</html>
အဲဒါေလး ကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
Space between characters
Characters တစ္ခုနဲ႕ တစ္ခုၾကား space ေတြကို ျခားခ်င္ရင္ေတာ့ letter-spacing ဆိုတာကို
သံုးလို႕ရပါတယ္။
<html>
<head>
<style type="text/css">
h1 {letter-spacing:2px;}
h2 {letter-spacing:-3px;}
</style>
</head>
<body>
<h1>This is heading 1</h1>
<h2>This is heading 2</h2>
</body>
</html>
အဲဒါကို ေအာက္ကလို ေပၚပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
22
Space Between Lines
Characters တစ္ခုနဲ႕ တစ္ခုၾကား space အကြာအေဝး ခ်ိန္ညိွလို႕ရသလို line တစ္ခုနဲ႕
တစ္ခုၾကားလည္း line-height နဲ႕ ခ်ိန္ညိွလို႕ရပါတယ္။ ေအာက္က example ေလးကို
ေလ့လာၾကည့္ပါ။
<html>
<head>
<style type="text/css">
p.small {line-height:90%;}
p.big {line-height:200%;}
</style>
</head>
<body>
<p>
This is a paragraph with a standard line-height.
The default line height in most browsers is about 110% to 120%.
This is a paragraph with a standard line-height.
</p>
<p class="small">
This is a paragraph with a smaller line-height.
This is a paragraph with a smaller line-height.
This is a paragraph with a smaller line-height.
</p>
<p class="big">
This is a paragraph with a bigger line-height.
This is a paragraph with a bigger line-height.
CSS for starter , written by saturngod ( www.saturngod.net )
23
This is a paragraph with a bigger line-height.
</p>
</body>
</html>
အဲဒါကိုေတာ့ ေအာက္ကလို ေတြ႕ရပါလိမ့္မယ္။
Right To Left Text
ဒါကေတာ့ ကၽြန္ေတာ္တုိ႕ေတြ သံုးခဲတယ္။ left to right ေရးရတဲ့ ဘာသာစကားေတြအတြက္
သံုးတာပါ။ ဥပမာ ေတာ့ မျပေတာ့ဘူး။ ဘယ္လုိေပၚလဲ သိခ်င္ရင္ စမ္းၾကည့္ႏိုင္ပါတယ္။
p{direction:rtl;}
Word Spacing
Character spacing , line spacing ေတြျပီးေတာ့ word spacing ေပါ့။
<html>
<head>
<style type="text/css">
p
{
word-spacing:30px;
}
</style>
</head>
CSS for starter , written by saturngod ( www.saturngod.net )
24
<body>
<p>
This is some text. This is some text.
</p>
</body>
</html>
word-spacing သံုးလိုက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
Nowrap
စာလံုးေတြကို wrap မျဖစ္ခ်င္ဘူး။ စာလံုးက တစ္တန္းျပည့္သြားေပမယ့္ ေအာက္တစ္လိုင္း
မဆင္းသြား ေစခ်င္ဘူးဆိုရင္ white-space ကို nowrap ေပးရပါတယ္။
p
{
white-space:nowrap;
}
ကိုယ့္ဘာသာ ကိုယ္စမ္းၾကည့္လုိက္ေပါ့။
Vertical Align
image ေတြမွာ ကၽြန္ေတာ္တုိ႕ေတြ HTML တုန္းက align ေတြလိုက္ထည့္ရတယ္။ text align
ညိွတာေပါ့။ အဲလိုမ်ဳိးပဲ CSS မွာလည္း သံုးလို႕ရပါတယ္။
<html>
<head>
<style type="text/css">
img.top {vertical-align:text-top;}
img.bottom {vertical-align:text-bottom;}
CSS for starter , written by saturngod ( www.saturngod.net )
25
</style>
</head>
<body>
<p>An <img src="w3schools_logo.gif" alt="W3Schools" width="270"
height="50" /> image with a default alignment.</p>
<p>An <img class="top" src="w3schools_logo.gif" alt="W3Schools"
width="270" height="50" /> image with a text-top alignment.</p>
<p>An <img class="bottom" src="w3schools_logo.gif" alt="W3Schools"
width="270" height="50" /> image with a text-bottom alignment.</p>
</body>
</html>
ဒီလိုေလးေပၚလိမ့္မယ္။
Text-shadow
စာလံုးေတြေနာက္မွာ shadow ထည့္ခ်င္တဲ့အခါမွာေတာ့ text-shadow ကို သံုးႏိုင္ပါတယ္။
<html>
<head>
<style>
p.test {
text-shadow: #6374AB 20px 25px 2px;
}
CSS for starter , written by saturngod ( www.saturngod.net )
26
</style>
</head>
<body>
<p class="test">This is txt shadow</p>
</body>
</html>
text-shadow: #အေရာင္ , X , Y, bluer ဆိုျပီး ထည့္ေပးရတာပါ။ အေပၚက code ေလးကို run
လိုက္ရင္ ေအာက္ကလို ေပၚပါလိမ့္မယ္။
CSS Text Properties
Property Description Values
color text color color
direction text direction ltr
rtl
line-height line တစ္ခုနဲ႕ တစ္ခုၾကား အျမင့္ normal
number
length
%
letter-spacing characters တစ္ခုနဲ႕ တစ္ခုၾကား အကြာအေဝး normal
length
text-align text align ညိွျခင္း left
right
center
justify
CSS for starter , written by saturngod ( www.saturngod.net )
27
Property Description Values
text-decoration add decoration to text none
underline
overline
line-through
blink
text-indent indent ေရႊ႕ျခင္း length
%
text-shadow အရိပ္ထည့္ျခင္း none
color
length
text-transform uppercase , lowercase ေျပာင္းျခင္း none
capitalize
uppercase
lowercase
vertical-align vertical align baseline
sub
super
top
text-top
middle
bottom
text-btoom
length
%
white-space wrap text လုပ္မလုပ္ normal
pre
nowrap
word-spacing word တစ္ခုနဲ႕တစ္ခုၾကား spacing normal
length
CSS for starter , written by saturngod ( www.saturngod.net )
28
Fonts
HTML မွာတုန္းက ကၽြန္ေတာ္တုိ႕ေတြ font tag နဲ႕ စာလံုးေတြကို ေျပာင္းခဲ့တာ
မွတ္မိအံုးမယ္ထင္ပါတယ္။ CSS မွာလည္း font ေတြကို ေျပာင္းလဲလုိ႕ရပါတယ္။ font tag သံုးမယ္ဆိုရင္
ေနရာ အမ်ားၾကီးမွာ font tag ေတြ လိုက္ထည့္ေနရလိမ့္မယ္။ ဒီေတာ့ CSS class ေလး သံုးျပီး
လြယ္လြယ္ကူကူ ဖန္တီးႏုိင္ပါတယ္။
Font Family
ေအာက္က code ေလးကို ေရးၾကည့္ျပီး စမ္းၾကည့္လိုက္ပါ။
<html>
<head>
<title>Font family</title>
<style type="text/css">
.time
{
font-family: "Times New Roman", Times, serif;
}
.arial
{
font-family: Arial,Verdana;
}
</style>
</head>
<body>
<p class="time">This is time class</p>
<p class="arial">This is arial class</p>
</body>
</html>
အဲဒါကို browser မွာ ဖြင့္လိုက္ရင္ ေအာက္ကလို ျမင္ရမယ္။ စာလံုး font မတူတာကို ေတြ႕ရမွာပါ။ ကိုယ္
အသံုးျပဳခ်င္တဲ့ font ကို font-family ထဲမွာ ေရးရံုပဲ။ font list ကို , နဲ႕ေရးရတယ္။ ေရွ႕ဆံုး font မရိွရင္
ဒုတိယ font ကို အသံုးျပဳပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
29
Font Style
စာလံုးေတြကို italic လုပ္ခ်င္တဲ့ အခါမွာေတာ့ font style ကို အသံုးျပဳရပါတယ္။
<html>
<head>
<style type="text/css">
p.normal {font-style:normal;}
p.italic {font-style:italic;}
p.oblique {font-style:oblique;}
</style>
</head>
<body>
<p class="normal">This is a paragraph, normal.</p>
<p class="italic">This is a paragraph, italic.</p>
<p class="oblique">This is a paragraph, oblique.</p>
</body>
</html>
အဲဒီ code ေလးကို browser မွာ ၾကည့္ရင္ ေအာက္ကလို ျမင္ရမွာပါ။
Font Size
CSS for starter , written by saturngod ( www.saturngod.net )
30
html မွာ font size ေတြကို font tag နဲ႕ ျပင္ရပါတယ္။ CSS မွာေတာ့ လြယ္လြယ္ကူကူေလး
ျပင္လုိ႕ရတယ္။ ေအာက္က code ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
h1 {font-size:40px;}
h2 {font-size:30px;}
p {font-size:14px;}
</style>
</head>
<body>
<h1>This is heading 1</h1>
<h2>This is heading 2</h2>
<p>This is a paragraph.</p>
<p>Specifying the font-size in px allows Firefox, Chrome, and
Safari to resize the text, but not Internet Explorer.</p>
</body>
</html>
အဲဒါေလးကို run လုိက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
Font size with em
CSS for starter , written by saturngod ( www.saturngod.net )
31
Internet Explorer မွာ တစ္ခါတစ္ေလ font size ေပၚတဲ့ ပံုျခင္းမတူတတ္ဘူး။ W3C ကေတာ့ px အစား
em ကို သံုးဖို႕ recommend လုပ္ထားပါတယ္။
h1 {font-size:2.5em;} /* 40px/16=2.5em */
h2 {font-size:1.875em;} /* 30px/16=1.875em */
p {font-size:0.875em;} /* 14px/16=0.875em */
16px em က 1 em နဲ႕ ညီပါတယ္။
Font Bold
font ေတြကို bold လုပ္ခ်င္တဲ့ အခါမွာ b tag ထည့္ေပးရပါတယ္။ တစ္ခါတည္း CSS မွာလည္း bold
လုပ္မယ္လုိ႕ ေျပာလို႕ရပါတယ္။
ေအာက္က code ေလးကို တခ်က္ၾကည့္လိုက္ပါ။
<html>
<head>
<style type="text/css">
p.normal {font-weight:normal;}
p.light {font-weight:lighter;}
p.thick {font-weight:bold;}
p.thicker {font-weight:900;}
</style>
</head>
<body>
<p class="normal">This is a paragraph.</p>
<p class="light">This is a paragraph.</p>
<p class="thick">This is a paragraph.</p>
<p class="thicker">This is a paragraph.</p>
</body>
</html>
အဲဒီ code ေလးကို run ၾကည့္လုိက္ရင္ ဒီလို ေလးျမင္ရပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
32
သိပ္ျပီး ထူးထူးျခားျခား ေျပာင္းလဲသြားတာကို ေတြ႕ရမွာ မဟုတ္ပါဘူး။ အဓိက bold ျဖစ္မျဖစ္ ပဲ
ကြာျခားမႈ ရိွပါတယ္။
Font Variant
font variant ကေတာ့ font ပံုစံေျပာင္းတာေပါ့။ အကုန္လံုးက စာလံုးအၾကီးေတြပဲ။ ဒါေပမယ့္
ေရွ႕ဆံုးအလံုးကို font အၾကီးလုပ္ခ်င္တဲ့အခါေတြမွာ သံုးလို႕ရပါတယ္။ ရွင္းသြားေအာင္ ေအာက္က
example ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
p.normal {font-variant:normal;}
p.small {font-variant:small-caps;}
</style>
</head>
<body>
<p class="normal">My name is Hege Refsnes.</p>
<p class="small">My name is Hege Refsnes.</p>
</body>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
33
Font Properties
Property Description Values
font font properties အားလံုး ကို
အသံုးျပဳရန္
font-style
font-variant
font-weight
font-size
font-family
font-family font နာမည္ font-name
font-size font အရြယ္အစား xx-small
x-small
small
medium
large
x-large
xx-large
smaller
larger
%
length
inherit
font-style font style normal
italic
oblique
inherit
font-variant small caps text ပံု normal
small-cpas
inherit
CSS for starter , written by saturngod ( www.saturngod.net )
34
Property Description Values
font-weight font bold ပံုစံ normal
bold
bolder
lighter
100
200
..
900
CSS for starter , written by saturngod ( www.saturngod.net )
35
Style Link
Link ေတြကိုလည္း css ကို အသံုးျပဳလုိ႕ရပါတယ္။ ဘယ္လိုမ်ဳိးေတြလဲဆိုေတာ့ စာလံုး အေရာင္ ၊ font ၊
background စတာေတြကို ထည့္သြင္းလုိ႕ရတာေပါ့။
link အတြက္ selector ၄ ခု ကိုသိဖုိ႕ လိုပါတယ္။
1. a:link - ပံုမွန္ အေျခအေန
2. a:visited - visited လုပ္ျပီးသား link
3. a:hover - mouse တင္လိုက္တဲ့ အခ်ိန္
4. a:active - mouse click လိုက္တဲ့ အခ်ိန္
ေအာက္က code ေလးကို စမ္းၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
a:link {color:#FF0000;} /* unvisited link */
a:visited {color:#00FF00;} /* visited link */
a:hover {color:#FF00FF;} /* mouse over link */
a:active {color:#0000FF;} /* selected link */
</style>
</head>
<head>
<a href="http://www.saturngod.net">Saturngod’s Blog</a>
</head>
</html>
မူရင္း အနီကေန mouse တင္လုိက္တဲ့ အခါမွာ စာအေရာင္ေျပာင္းသြားတာေတြ႕ပါမယ္။ click လုပ္ျပီး
mouse ကို ဖိထားခ်ိန္မွာေတာ့ အျပာေရာင္ ေျပာင္းသြားပါမယ္။ Link ကို တစ္ေခါက္ႏိွပ္ျပီးသြားရင္
သို႕မဟုတ္ သြားထားဖူးရင္ေတာ့ အစိမ္းေရာင္ ျဖစ္ေနပါလိမ့္မယ္။
Common Link Style
CSS for starter , written by saturngod ( www.saturngod.net )
36
link နဲ႕ အဓိက တြဲသံုးလို႕ရတဲ့ style ေလးေတြ ျပသြားပါမယ္။ link ရဲ႕ selector ၄ ခုကို
နားလည္သြားရင္ css code ေတြကို စိတ္ၾကိဳက္ထည့္သြင္းေရးသားႏိုင္ပါျပီ။ စာသားအေရာင္ ေနာက္ခံ
အေရာင္ အျပင္ အေရာင္မ်ဳိးမ်ဳိး လြယ္လင့္တကူ ေရးသားႏိုင္ပါတယ္။
Text Decoration
link နဲ႕ အဓိက အသံုးမ်ားတာကေတာ့ text-decoration ပါ။ သူက ဘာလုပ္ေပးတာလဲဆိုေတာ့ link မွာ
underline ေဖ်ာက္ခ်င္တဲ့ အခါမွာ အသံုးျပဳႏိုင္ပါတယ္။
a:link {text-decoration:none;}
a:hover{text-decoration: underline}
link က ပံုမွန္ underline ပါေပမယ့္ text-decoration:none ဆိုရင္ underline ေပ်ာက္သြားပါတယ္။
mouse တင္လိုက္တဲ့ အခါမွာ ျပန္ေပၚခ်င္တဲ့အတြက္ေၾကာင့္ a:hover မွာ text-decoration:underline
ဆိုျပီး သံုးလိုက္ပါတယ္။
background color
ကၽြန္ေတာ္ ေထြေထြ ထူးထူး မေျပာေတာ့ပါဘူး။ background-color နဲ႕ ပတ္သက္ျပီးေတာ့ ကၽြန္ေတာ္
အေပၚမွာ ေျပာထားခဲ့ျပီးပါျပီ။ link မွာ css က code ေတြကို လြယ္လင့္တကူ အသံုးျပဳႏိုင္ပါတယ္။
အတူတူပါပဲ။ link မွာ အဓိက selector ၄ ခုကို အသံုးျပဳတယ္ဆိုတာကို မွတ္မိဖို႕ပဲလုိပါတယ္။
<html>
<head>
<style type="text/css">
a:link {background-color:#B2FF99;}
a:visited {background-color:#FFFF85;}
a:hover {background-color:#FF704D;}
a:active {background-color:#FF704D;}
</style>
</head>
<head>
<a href="http://www.google.com">Google</a>
</head>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
37
Lists
List ဆိုတာကေတာ့ ul နဲ႕ ol ပဲ ေပါ့။ ul က အခုေနာက္ပိုင္း CSS ေတြမွာ table အစား အသံုးျပဳလာတာ
ေတြ႕ရပါတယ္။ table အစား အသံုးျပဳတယ္ဆိုတာက ရိုးရိုး html မွာ မျဖစ္ႏိုင္သလိုပဲ။ ဒါေပမယ့္ CSS နဲ႕
ေပါင္းျပီး သံုးလိုက္တဲ့ အခါမွာေတာ့ Table လုိမ်ဳိး ဖန္တီးလာႏိုင္ပါတယ္။
Different List Item Markers
<html>
<head>
<style type="text/css">
ul.a {list-style-type:circle;}
ul.b {list-style-type:square;}
ol.c {list-style-type:upper-roman;}
ol.d {list-style-type:lower-alpha;}
</style>
</head>
<body>
<p>Example of unordered lists:</p>
<ul class="a">
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ul>
<ul class="b">
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ul>
<p>Example of ordered lists:</p>
<ol class="c">
CSS for starter , written by saturngod ( www.saturngod.net )
38
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ol>
<ol class="d">
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ol>
</body>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
ပံုမွန္ HTML မွာလည္း လြယ္လင့္တကူ ဖန္တီးႏိုင္သလို css နဲ႕လည္း ဖန္တီးႏိုင္ပါတယ္။ CSS ရဲ႕
အားသာခ်က္ေတြကိုေတာ့ ကၽြန္ေတာ္ေျပာျပီးပါျပီ။ ဒါေၾကာင့္ css ကို အသံုးျပဳျပီး ေျပာင္းလဲလို႕ရတာဟာ
CSS for starter , written by saturngod ( www.saturngod.net )
39
list ေတြ အမ်ားၾကီးအတြက္ အဆင္ေျပလွပါတယ္။ အခုမွာေတာ့ list မွာ ဘာေတြပါလဲဆိုတာေလာက္ပဲ
ေရးပါအံုးမယ္။ ေနာက္ပိုင္းမွာေတာ့ list နဲ႕ menu တည္ေဆာက္ပံုေတြ ရွင္းျပသြားပါမယ္။
value for Unordered list property
Value Description
none No marker
disc Default. စက္ဝိုင္းအမည္း
circle စက္ဝုိင္း
square ေလးေထာင့္ပံ
Value for Ordered Lists
Value Description
armenian Traditional Amenian
numbering
decimal number
decimal-leading-zero number padded by initial
zeros (01,02,03,etc)
geogrian tradional Georgian
numbering (an,ban,gan,etc)
lower-alpha lower-alpha (a,b,c,d,etc)
lower-greek lower-greek
(alpha,beta,gamma,etc)
lower-latin lower-latin(a,b,c,d,etc)
lower-roman lower-roman(i,ii,iii,etc)
upper-alpha upper-alpha (A,B,C,etc)
upper-latin upper-latin(A,B,C,D,etc);
upper-roman upper-roman( I, II,III,etc)
CSS for starter , written by saturngod ( www.saturngod.net )
40
Image List
တစ္ခါတစ္ေလ ကၽြန္ေတာ္တုိ႕ေတြ list ေတြကု ကိုယ္ပိုင္ image ေလးေတြနဲ႕ ထည့္ခ်င္တယ္။ A,B,C,D ,
I, II , III စတာေတြကို မသံုးခ်င္ဘူး။ အဲဒါဆိုရင္ေတာ့ HTML တခုတည္းနဲ႕ မရေပမယ့္ CSS နဲ႕
ေပါင္းျပီး အလြယ္တကူ ဖန္တီးႏုိင္ပါတယ္။
<html>
<head>
<style type="text/css">
ul
{
list-style-image:url('sqpurple.gif');
}
</style>
</head>
<body>
<ul>
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ul>
</body>
</html>
အဲဒါကို browser မွာ ၾကည့္လုိက္ရင္ ေအာက္ကလို ေတြ႕ပါလိမ့္မယ္။ image ကေတာ့
ခပ္ေသးေသးပဲေပါ့။ 9 x 9 px ဆုိရင္ ရပါျပီ။
IE , Opera တုိ႕မွာ နည္းနည္းေလး image က ျမင့္ေနပါလိမ့္မယ္။ Chrome, Safari, Firefox
တုိ႕ေလာက္ ၾကည့္မေကာင္းပါဘူး။ ဒါေလးကို ဂရုိစိုက္ဖို႕ လိုပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
41
Cross browser Solution
အကုန္လံုးမွာ ေသခ်ာေပၚဖို႕အတြက္ဆိုရင္ေတာ့ နည္းနည္း ပိုျပီး ထပ္ေရးရပါလိမ့္မယ္။
<html>
<head>
<style type="text/css">
ul
{
list-style-type:none;
padding:0px;
margin:0px;
}
li
{
background-image:url(sqpurple.gif);
background-repeat:no-repeat;
background-position:0px 5px;
padding-left:14px;
}
</style>
</head>
<body>
<ul>
<li>Coffee</li>
<li>Tea</li>
<li>Coca Cola</li>
</ul>
</body>
</html>
ဒီ code က နည္းနည္းမ်ားသြားျပီ။ ul ကို list-style-type ကို none လုပ္ျပီး padding, margin ကို 0px
ေပးျပီး ညိွလိုက္တယ္။ ျပီးမွ li ကို background-image နဲ႕ ပံုထည့္ျပီး position ကို ေရႊ႕လိုက္တာေပါ့ဗ်ာ။
CSS for starter , written by saturngod ( www.saturngod.net )
42
အဲဒီနည္းလမ္းက အရင္ကနည္းလမ္းထက္ ေကာင္းတာေတာ့ အမွန္ပဲဗ်။ browser အားလံုးမွာ
အဆင္ေျပေျပ ျမင္ရတာေပါ့။
Shorthand property
တစ္ခါတစ္ေလ လိုင္းတစ္ေၾကာင္းတည္းနဲ႕ ျပီးသြားေစခ်င္တဲ့ အခါမွာ shorthand style သံုးျပီး
ေ၇းလိုက္လို႕ရပါတယ္။
ul
{
list-style:square url("sqpurple.gif");
}
ေရးတဲ့ အခါမွာေတာ့
• list-style-type
• list-style-position
• list-style-image
ဆိုျပီး အစီအစဥ္တိုင္းေရးပါတယ္။ ၃ ခုလံုး တျပိဳင္တည္း မဟုတ္ရင္ေတာင္ တစ္ခုတည္းပဲ
ျဖစ္ျဖစ္ ၂ ခုတြဲပဲ ျဖစ္ျဖစ္ တြဲျပီး ေရးႏိုင္ပါတယ္။
CSS List Properties
Property Description Values
list-style property ေတ အကုန္
တစ္ေနရာတည္းမွာ ျဖည့္ျခင္း
list-style-type
list-style-position
list-style-image
list-style-image list item မွာ ပံနဲ႕ အသံးျပဳ>? @ AB URL
none
list-style-position list item ေပၚC D EA ေနရာ inside
outside
CSS for starter , written by saturngod ( www.saturngod.net )
43
Property Description Values
list-style-type list item အမ်ဳGB H I J B none
disc
circle
square
decimal
decimal-leading-zero
armenian
georgian
lower-alpha
upper-alpha
lower-greek
lower-latin
upper-latin
lower-roman
upper-roman
CSS for starter , written by saturngod ( www.saturngod.net )
44
CSS Tables
HTML table ကို CSS နဲ႕တြဲျပီး သံုးတဲ့ အခါမွာ ေအာက္ကလုိမ်ဳိး table တစ္ခု ဖန္တီးႏို္င္ပါတယ္။
Tables Borders
အေပၚက ပံုမွာ table က border color နဲ႕ ေတြ႕ရမွာပါ။
<html>
<head>
<style type="text/css">
table,th,td
{
border:1px solid black;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
</tr>
CSS for starter , written by saturngod ( www.saturngod.net )
45
<tr>
<td>Peter</td>
<td>Griffin</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
</tr>
</table>
</body>
</html>
အဲဒီ code ေလးကို run ၾကည့္လုိက္ပါ။ ေအာက္ကလို ျမင္ရပါမယ္။ CSS က border တစ္ခုပဲ
ထည့္ထားပါတယ္။ border ကိုေတာ့ ေနာက္ပိုင္းမွာ ရွင္းျပပါမယ္။ သီးသန္႕ ရွင္းျပမွျဖစ္မွာမုိ႕ပါ။
Collapse Borders
အေပၚမွာ boder က ဟ ေနပါတယ္။ တစ္ကယ္လုိ႕ border တစ္ခုတည္း ျဖစ္ခ်င္ရင္ေတာ့ Collapse
Borders ဆိုတာကို သံုးရပါမယ္။ code ကို တခ်က္ေလာက္ ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
table
{
border-collapse:collapse;
}
table, td, th
{
border:1px solid black;
}
CSS for starter , written by saturngod ( www.saturngod.net )
46
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
</tr>
</table>
<p><b>Note:</b> If a !DOCTYPE is not specified, the bordercollapse
property can produce unexpected results.</p>
</body>
</html>
border-collapse:collapse;
ဆိုတာေလး ထည့္လိုက္တဲ့ အခါမွာေတာ့ border တစ္ခုတည္း ျဖစ္သြားပါတယ္။
Table နဲ႕ ပတ္သက္လုိ႕မ်ားမ်ား စားစားမရိွပါဘူး။ ပံုမွန္ CSS ေတြကို ေခၚသံုးသြားတာ။ အဓိကေတာ့
html tag ေတြကို css နဲ႕ တြဲသံုးလုိက္တာပါ။ table, th, td စတဲ့ selector ေတြကို ယူသံုးျပီး ပံုမွန္ CSS
ပဲ သံုးသြားတာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
47
Table Width And Height
<html>
<head>
<style type="text/css">
table,td,th
{
border:1px solid black;
}
table
{
width:100%;
}
th
{
height:50px;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
CSS for starter , written by saturngod ( www.saturngod.net )
48
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr>
<td>Cleveland</td>
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
</html>
code ေလးကေတာ့ ပံုမွန္ပါပဲ။ table ရဲ႕ width က 100% သံုးလိုက္ျပီးေတာ ့ th ရဲ႕ height ကိုေတာ့
50 px ေပးလုိက္ပါတယ္။ သာမာန္ ရိုးရွင္း တဲ့ code ေလးပါပဲ။
Table Text Alignment
Text alignment မွာ vertical နဲ႕ horizontal ဆိုျပီး ၂ မ်ဳိးရိွပါတယ္။ horizontal ကေတာ့ text-align
ကိုပဲသံုးပါတယ္။ text-align မွာ left, right, center, justify ဆိုျပီး ရိွပါတယ္။ အခုေတာ့ သိသာေအာင္
text-align:right;
နဲ႕ ျပထားပါတယ္။
<html>
CSS for starter , written by saturngod ( www.saturngod.net )
49
<head>
<style type="text/css">
table,td,th
{
border:1px solid black;
}
td
{
text-align:right;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr>
<td>Cleveland</td>
CSS for starter , written by saturngod ( www.saturngod.net )
50
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
</html>
အဲဒီ code ကို run လုိက္ရင္
စာေတြ အကုန္ ညာဖက္ ကပ္ေနတာကို ေတြ႕မွာပါ။
vertical align ကေတာ့ top , bottom , middle ဆိုျပီး ရိွပါတယ္။ တခ်က္ေလာက္ code ေလးကို
ၾကည့္လုိက္ရေအာင္
td
{
height:50px;
vertical-align:bottom;
}
ကိုပဲ သံုးထားတယ္။
<html>
<head>
<style type="text/css">
table,td,th
{
border:1px solid black;
CSS for starter , written by saturngod ( www.saturngod.net )
51
}
td
{
text-align:right;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr>
<td>Cleveland</td>
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
CSS for starter , written by saturngod ( www.saturngod.net )
52
</html>
အဲဒါက run လုိက္ရင္ ေအာက္ကလို ေတြ႕ပါမယ္။
အကုန္လံုး ေအာက္မွာ ေရာက္ေနတာကို ေတြ႕ပါလိမ့္မယ္။
Table Padding
table မွာ padding က အေရးၾကီးပါတယ္။ padding က ဘာလဲဆိုတာကိုေတာ့ HTML table အခန္းမွာ
ျပန္လည္ ဖတ္ရႈႏိုင္ပါတယ္။ ရွင္းေအာင္ ေျပာရရင္ေတာ့ padding က border နဲ႕ စာ အကြာအေဝးလို႕
ဆိုရပါလိမ့္မယ္။
padding အတြက္ကေတာ့
td
{
padding:15px;
}
အဲလိုမ်ဳိးေရးပါတယ္။ code အျပည့္အစံုကေတာ့
<html>
CSS for starter , written by saturngod ( www.saturngod.net )
53
<head>
<style type="text/css">
table, td, th
{
border:1px solid black;
}
td
{
padding:15px;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
<tr>
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr>
<td>Cleveland</td>
CSS for starter , written by saturngod ( www.saturngod.net )
54
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
</html>
အဲဒါကို run ၾကည့္လုိက္ရင္
စာသားေတြက ေဘာင္နဲ႕ ျခားသြားတာကို ေတြ႕ႏိုင္ပါလိမ့္မယ္။
Table Color
table မွာ ေနာက္ထပ္ လွပ ေအာင္ျပင္ရမယ့္ အပိုင္းကေတာ့ color ပါပဲ။ color ဆိုတဲ့အထဲမွာ border
color နဲ႕ background color ဆုိျပီး ရိွပါတယ္။ border အေၾကာင္းကိုေတာ့ basic css style ေတြ
ျပီးသြားျပီး box Model အပိုင္းမွာ ရွင္းျပေပးပါ့မယ္။
table အတြက္က color ကေတာ့
table, td, th
{
border:1px solid green;
}
CSS for starter , written by saturngod ( www.saturngod.net )
55
th
{
background-color:green;
color:white;
}
ဆိုျပီး သံုးပါတယ္။ တခ်က္ေလာက္ code အျပည့္အစံုကို ၾကည့္လုိက္ရေအာင္။
<html>
<head>
<style type="text/css">
table, td, th
{
border:1px solid green;
border-collapse:collapse;
padding:5px;
}
th
{
background-color:green;
color:white;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
<tr>
CSS for starter , written by saturngod ( www.saturngod.net )
56
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr>
<td>Cleveland</td>
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
</html>
ကဲ.. အဲဒီ code ေလးကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
ပံုမွန္ table နဲ႕ လံုးဝကို မတူေတာ့ပါဘူး။ ကၽြန္ေတာ္တို႕ code ကို နည္းနည္းေလး ျပန္ျပင္ရေအာင္။
တစ္ေၾကာင္းျပီးတိုင္း အေရာင္ေလးေတြ ေျပာင္းသြားေအာင္ေပါ့။
tr.alt
{
background-color:#D5FFC8;
}
CSS for starter , written by saturngod ( www.saturngod.net )
57
ဆိုျပီး ထပ္ျဖည့္လိုက္မယ္။code အျပည့္အစံုကိုေတာ့ ေအာက္မွာ ၾကည့္ပါ။ tr တစ္ခုေက်ာ္တိုင္းမွာ alt
ဆိုျပီး class ေတြ လိုက္ျဖည့္ထားတာကို ေတြ႕ပါလိမ့္မယ္။
<html>
<head>
<style type="text/css">
table, td, th
{
border:1px solid green;
border-collapse:collapse;
padding:5px;
}
tr.alt
{
background-color:#D5FFC8;
}
th
{
background-color:green;
color:white;
}
</style>
</head>
<body>
<table>
<tr>
<th>Firstname</th>
<th>Lastname</th>
<th>Savings</th>
</tr>
<tr>
<td>Peter</td>
<td>Griffin</td>
<td>$100</td>
</tr>
CSS for starter , written by saturngod ( www.saturngod.net )
58
<tr class='alt'>
<td>Lois</td>
<td>Griffin</td>
<td>$150</td>
</tr>
<tr>
<td>Joe</td>
<td>Swanson</td>
<td>$300</td>
</tr>
<tr class='alt'>
<td>Cleveland</td>
<td>Brown</td>
<td>$250</td>
</tr>
</table>
</body>
</html>
အဲဒါကို run လိုက္ရင္ေတာ့
ဆိုျပီး ျမင္ရပါလိမ့္မယ္။
အခုဆိုရင္ေတာ့ CSS style basic ပိုင္းျပီးသြားပါျပီ။ ေနာက္အပိုင္းကေတာ့ box model
အေၾကာင္းလာပါေတာ့မယ္။ border ေတြ အေၾကာင္းေပါ့။
CSS for starter , written by saturngod ( www.saturngod.net )
59
Chapter 3: CSS Box Model
Box Model
CSS Box Model ဆိုတာကေတာ့ CSS မွာ တြဲျပီးသံုးရမယ့္ margin , padding , border စတာေတြကို
ေျပာျပသြားမွာပါ။ margin နဲ႕ padding က အစ ေလ့လာသူေတြ အေနနဲ႕
အျမဲေရာေထြးေနတတ္ပါတယ္။ ရွင္းသြားေအာင္ ေအာက္က ပံုေလးကို တခ်က္ၾကည့္လိုက္ပါ။
content ဆိုတာကေတာ့ ကၽြန္ေတာ္တုိ႕ စာေတြ ေပၚမယ့္ေနရာေပါ့။
padding ဆိုတာက ေတာ့ border နဲ႕ content ၾကား အကြာအေဝးေပါ့။
border ဆိုတာကေတာ့ content ရဲ႕ ေဘာင္ေပါ့။
margin ကေတာ့ လက္ရိွ ရိွေနတဲ့ ေနရာကေန အကြာအေဝးလို႕ ဆိုလို႕ရပါတယ္။
ပိုျပီး ရွင္းသြားေအာင္ ေအာက္က code ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
div.ex
CSS for starter , written by saturngod ( www.saturngod.net )
60
{
width:220px;
padding:10px;
border:5px solid gray;
margin:0px;
}
</style>
</head>
<body>
<img src="250px.gif" width="250" height="1" /><br /><br />
<div class="ex">The line above is 250px wide.<br />
The total width of this element is also 250px.</div>
<p><b>Important:</b> This example will not display correctly in
IE!<br />
However, we will solve that problem in the next example.</p>
</body>
</html>
အဲဒါကို browser မွာ ေအာက္ကလို ျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
61
padding 10px ေၾကာင့္ အေပၚက img နဲ႕ 10 px ေလာက္ကြာေနတာကို ေတြ႕ပါမယ္။ border 5 px
လုပ္ထားတဲ့အတြက္ေၾကာင့္ div ရဲ႕ border က ထူေနပါတယ္။ solid ျဖစ္တဲ့အတြက္ေကာင့္ လိုင္းက
အျပည့္ေပၚပါတယ္။ အေရာင္ကေတာ့ gray ေပါ့။
CSS Border
ကဲ... table အခန္းကတည္းက ပါလာတဲ့ border အေၾကာင္း အခု ရွင္းပါျပီ။ border ဆိုတာ
ဘာလဲဆိုတာကေတာ့ ေထြေထြထူးထူး ရွင္းဖို႕ မလိုေတာ့ပါဘူး။
Border Style
Border style ကေတာ့ border ကို ဘယ္လိုမ်ဳိး ပံုလဲဆိုတာအတြက္ေပါ့။ border style မွာ solid
border ကိုေတာ့ အေရွ႕မွာ သံုးခဲ့ပါတယ္။
border-style values:
value ေတြက dotted, dashed , solid, double, grrove , ridge , inset, outset ေတြပါ။
ပံုေတြကေတာ့ ေအာက္ကလို ျမင္ရပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
62
<html>
<head>
<style type="text/css">
p.none {border-style:none;}
p.dotted {border-style:dotted;}
p.dashed {border-style:dashed;}
p.solid {border-style:solid;}
p.double {border-style:double;}
p.groove {border-style:groove;}
p.ridge {border-style:ridge;}
p.inset {border-style:inset;}
p.outset {border-style:outset;}
p.hidden {border-style:hidden;}
</style>
</head>
<body>
<p class="none">No border.</p>
<p class="dotted">A dotted border.</p>
<p class="dashed">A dashed border.</p>
<p class="solid">A solid border.</p>
<p class="double">A double border.</p>
<p class="groove">A groove border.</p>
CSS for starter , written by saturngod ( www.saturngod.net )
63
<p class="ridge">A ridge border.</p>
<p class="inset">An inset border.</p>
<p class="outset">An outset border.</p>
<p class="hidden">A hidden border.</p>
</body>
</html>
အဲဒါကို run ၾကည့္လုိက္ရင္ေတာ့
Border Width
border width ကေတာ့ border အထူအပါးကုိ အသံုးျပဳပါတယ္။ border-width ဆိုျပီး သံုးပါတယ္။
<html>
<head>
<style type="text/css">
p.one
{
border-style:solid;
CSS for starter , written by saturngod ( www.saturngod.net )
64
border-width:5px;
}
p.two
{
border-style:solid;
border-width:medium;
}
p.three
{
border-style:solid;
border-width:1px;
}
</style>
</head>
<body>
<p class="one">Some text.</p>
<p class="two">Some text.</p>
<p class="three">Some text.</p>
<p><b>Note:</b> The "border-width" property does not work if it is
used alone. Use the "border-style" property to set the borders
first.</p>
</body>
</html>
အဲဒါေလးကို browser မွာ ဒီလုိျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
65
border အထူအပါး ေတြ ကြာျခားေနတာကို သတိျပဳႏိုင္ပါတယ္။
Border Color
border color ကေတာ့ border ရဲ႕ အေရာင္ေတြေပါ့။ HTML မွာ အေရာင္သံုးတဲ့ ကိစၥကို ကၽြန္ေတာ္
ေရးခဲ့ဖူးပါတယ္။ name သို႕မဟုတ္ #RRGGBB နဲ႕ အသံုျပဳပါတယ္။ CSS မွာေတာ့ rgb(0,0,255) လိုမ်ဳိး
အသံုးျပဳလို႕ရပါေသးတယ္။
အခု code ေလးမွာေတာ့ border-color ကို သံုးထားတာကိုေတြ႕ႏိုင္ပါတယ္။
<html>
<head>
<style type="text/css">
p.one
{
border-style:solid;
border-color:red;
}
p.two
{
border-style:solid;
border-color:#98bf21;
}
</style>
</head>
<body>
<p class="one">A solid red border</p>
<p class="two">A solid green border</p>
CSS for starter , written by saturngod ( www.saturngod.net )
66
<p><b>Note:</b> The "border-color" property does not work if it is
used alone. Use the "border-style" property to set the borders
first.</p>
</body>
</html>
အဲဒါကိုေတာ့ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
Border- Individual sides
left လား right လား top လား bottom လား စျပီး အေသးစိတ္ကို အသံုးျပဳလို႕ရေအာင္လည္း CSS မွာ
ေရးသားႏိုင္ပါတယ္။ တစ္ခါတစ္ေလ ညာဘက္မွာ border style တစ္မ်ဳိး ေျပာင္းျပီး ေဖာ္ျပခ်င္တဲ့
အခါမ်ဳိးမွာေပါ့
p
{
border-top-style:dotted;
border-right-style:solid;
border-bottom-style:dotted;
border-left-style:solid;
}
ဆိုျပီး အသံုးျပဳပါတယ္။ code အျပည့္အစံုနဲ႕ စမ္းၾကည့္မယ္ဆိုရင္ေတာ့
<html>
<head>
<style type="text/css">
p
{
CSS for starter , written by saturngod ( www.saturngod.net )
67
border-top-style:dotted;
border-right-style:solid;
border-bottom-style:dotted;
border-left-style:solid;
}
</style>
</head>
<body>
<p>2 different border styles.</p>
</body>
</html>
ဘယ္လိုမ်ဳိး ေပၚမလဲဆိုရင္ေတာ့
တကယ္လုိ႕ ၄ ေၾကာင္းမေရးပဲနဲ႕ ၁ေၾကာင္းတည္း ဒီလိုေရးလို႕ရပါတယ္။
border-style:dotted solid;
ေရွ႕ကေတာ့ အေပၚနဲ႕ ေအာက္ျဖစ္ျပီး ေနာက္ကေန ဘယ္နဲ႕ ညာနဲ႕ ပါ။ အေပၚနဲ႕ ေအာက္
အတူတူ ပဲျဖစ္ေနရင္ ဘယ္နဲ႕ ညာ အတူတူပဲ ျဖစ္ေနရင္ တစ္ေၾကာင္းတည္းနဲ႕ ေရးလို႕ရပါတယ္။
border-style မွာ value ကို ၄ ခုေလာက္ထိ ထည့္လို႕ရပါတယ္။
border-style: dotted solid double dashed;
top border က dotted
right border က solid
bottom border က double
left border ကေတာ့ dashed
border-style: dotted solid double;
CSS for starter , written by saturngod ( www.saturngod.net )
68
top border က dotted
right နဲ႕ left border က solid
bottom border က double
border-style: dotted solid;
top နဲ႕ bottom border က dotted
right နဲ႕ left border က solid
border-style: dotted;
border အားလံုး dotted
Border - Shorthand property
တကယ္လံုးကို ေပါင္းျပီး တစ္ေၾကာင္းတည္း ေရးခ်င္ရင္တာ့ border: ဆိုျပီး ေရးပါတယ္။ table
အခန္းမွာေရးသြားတာက shorthand ပံုစံပါ။ border 5px solid red အတြက္ အေၾကာင္းေတြ
အမ်ားၾကီး မေရးပဲ
border:5px solid red;
ဆိုျပီး ေရးလုိ႕ရပါတယ္။
property ကေတာ့
border-width
border-style
border-color
ဆိုျပီး အသံုးျပဳပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
69
CSS Border Properties
Property Description Values
border properties အားလံုး အတြက္ border-width
border-style
border-color
border-bottom border bottom properties
အားလံုးအတြက္
border-bottom-width
border-bottom-style
border-bottom-color
border-bottom-color bottom border color
ေျပာင္းရန္
border-color
border-bottom-style border bottom style ျပင္ရန္ border-style
border-bottom-width border bottom width ကို
ျပင္ရန္
border-width
border-color border အားလံုးအတြက္ color color_name
hex_number
rgb_number
transparent
border-left border left properties
အားလံုးအတြက္
border-left-width
border-left-style
border-left-color
border-left-color border left color အတြက္
ျပင္ရန္
border-color
border-left-style border left style ျပင္ရန္ border-style
border-left-width border left width ျပင္ရန္ border-width
border-right border right အတြက္
အကုန္ျပင္ရန္
border-right-width
border-right-style
border-right-color
border-right-color border right color ျပင္ရန္ border-color
border-right-style border right style ျပင္ရန္
အတြက္
border-style
CSS for starter , written by saturngod ( www.saturngod.net )
70
Property Description Values
border-right-width border right width
ျပင္ရန္အတြက္
border-width
border-style border အားလံုးအတြက္ style none
hidden
dotted
dashed
solid
double
groove
ridge
inset
outset
inherit
border-top border top ႏွင့္ သက္ဆုိင္ရာ
အားလံုး
border-top-width
border-top-style
border-top-color
border-top-color border top color ျပင္ရန္ border-color
border-top-style border top style ျပင္ရန္ border-style
border-top-width border top width ျပင္ရန္ border-width
border-width border အားလံုးရဲ႕ width thin
medium
thick
length
CSS for starter , written by saturngod ( www.saturngod.net )
71
CSS Outline
outline ကေတာ့ link ေတြထည့္လိုက္တဲ့အခါ ပံုေတြ ၊ စာေတြရဲ႕ ပတ္လည္မွာ dotted line
ေလး ကို ေျပာတာပါ။ သူ႕ကို border နဲ႕ မွားတတ္ပါတယ္။ ေသခ်ာေအာင္ ေအာက္က example
ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
p
{
border:1px solid red;
outline:green dotted thick;
}
</style>
</head>
<body>
<p><b>Note:</b> IE8 supports the outline properties only if a !
DOCTYPE is
specified.</p>
</body>
</html>
အဲဒီ code ေလးကို run လိုက္တဲ့ အခါမွာ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
border ကေတာ့ အနီေရာင္ျဖစ္ျပီး outline ကေတာ့ အစိမ္းေရာင္ dotted ေလးနဲ႕
ျပထားပါတယ္။
outline ကိုေတာ့
outline:[color] [style] [width];
CSS for starter , written by saturngod ( www.saturngod.net )
72
ဆိုျပီး အသံုးျပဳပါတယ္။
CSS Margin
CSS မွာ margin နဲ႕ padding ပိုင္းက အေရးၾကီးပါတယ္။ margin နဲ႕ padding ကို အစပိုင္းမွာ
ေရာေထြးေနတတ္ပါတယ္။ သို႕ေပမယ့္ margin နဲ႕ padding က လံုးဝ ကြာျခားပါတယ္။ ဒီ
အေၾကာင္းကို HTML မွာတုန္းက ကၽြန္ေတာ္ ေျပာခဲ့ျပီးပါျပီ။ margin ကို ေအာက္ကလို မ်ဳိး
အသံုးျပဳပါတယ္။
margin:25px 50px 75px 100px;
top margin က 25px
right margin က 50px
bottom margin က 75px
left margin က 100px
လို႕ ဆိုတာပါ။
margin: 25px 50px 75px;
top margin က 25px
right နဲ႕ left margin က 50px
bottom margin ကေတာ့ 75px
လုိ႕ ဆိုတာပါ။
margin:25px 50px;
top နဲ႕ bottom က 25px
right နဲ႕ left ကေတာ့ 50px
ပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
73
margin:25px;
margin အားလံုးက 25px
လို႕ဆိုပါတယ္။
margin ကို စမ္းထားတဲ့ example ေလး ၾကည့္ရေအာင္။
<html>
<head>
<style type="text/css">
p
{
background-color:yellow;
}
p.margin
{
margin:100px 50px;
}
</style>
</head>
<body>
<p>This is a paragraph with no specified margins.</p>
<p class="margin">This is a paragraph with specified margins.</p>
</body>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ေတြ႕မွာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
74
top နဲ႕ bottom က 100px ျဖစ္ျပီး left နဲ႕ right က 50px ကြာထားတာကို ေတြ႕ႏိုင္ပါတယ္။
margin က အျပင္ကေန အကြာအေဝးပါ။ padding ကေတာ့ အတြင္း အကြာအေဝးေပါ့။
ေနာက္ျပီး တစ္ခု ျခင္းဆီ အေနနဲ႕ ခြဲေရးလည္းရပါတယ္။
margin-top:100px;
margin-bottom:100px;
margin-right:50px;
margin-left:50px;
margin top က 100 px , bottom ကလည္း 100px , left နဲ႕ right ကေတာ့ 50 px ဆိုျပီး
တစ္ခုျခင္းဆီ ေရးသားထားတာပါ။
CSS Padding
padding ကလည္း margin လိုမ်ဳိးပါပဲ။ သူကေတာ့ အတြင္းကေန အကြာအေဝးပါ။ သူ႕
အသံုးျပဳပံုကလည္း margin အတိုင္းပါပဲ။
padding:25px 50px 75px 100px;
top padding က 25px
right padding က 50px
bottom padding က 75px
left padding က 100px
လို႕ ဆိုတာပါ။
padding: 25px 50px 75px;
CSS for starter , written by saturngod ( www.saturngod.net )
75
top padding က 25px
right နဲ႕ left padding က 50px
bottom padding ကေတာ့ 75px
လုိ႕ ဆိုတာပါ။
padding:25px 50px;
top နဲ႕ bottom က 25px
right နဲ႕ left ကေတာ့ 50px
ပါ။
padding:25px;
padding အားလံုးက 25px
လို႕ဆိုပါတယ္။
သူ႕ကိုလည္း တစ္ခု ျခင္းဆီ ခြဲေရးလို႕ရပါတယ္။
padding-top:25px;
padding-bottom:25px;
padding-right:50px;
padding-left:50px;
ကဲ။ ဥပမာေလး ၾကည့္ရေအာင္။
<html>
<head>
<style type="text/css">
p
{
background-color:yellow;
CSS for starter , written by saturngod ( www.saturngod.net )
76
}
p.padding
{
padding-top:25px;
padding-bottom:25px;
padding-right:50px;
padding-left:50px;
}
</style>
</head>
<body>
<p>This is a paragraph with no specified padding.</p>
<p class="padding">This is a paragraph with specified paddings.</
p>
</body>
</html>
အဲဒါကိုေလးကို run လုိက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
အဲဒါဆိုရင္ေတာ့ padding နဲ႕ margin ကို သေဘာေပါက္ေလာက္ပါျပီ။
အခုဆိုရင္ေတာ့ CSS အေျခခံအဆင့္ေလာက္ကို သိသြားျပီလုိ႕ ဆိုႏိုင္ပါျပီ။
ေနာက္အခန္းေတြကေတာ့ advanced ပိုင္း နည္းနည္းေရာက္လာပါျပီ။ ဒါေၾကာင့္
example ေတြ အကုန္မျပေတာ့ သလို အေသးစိတ္႐ွင္းလင္းခ်က္ေတြလည္း သိပ္ျပီး
ပါလာေတာ့မွာ မဟုတ္ပါဘူး။
CSS for starter , written by saturngod ( www.saturngod.net )
77
Chapter 4: Advanced CSS
Grouping CSS
CSS ေတြေရးတဲ့ အခါမွာ တူညီတဲ့ code ေတြကို စုစည္းျပီး ေၾကျငာလုိ႕ရပါတယ္။ ဥပမာ
h1
{
color:green;
}
h2
{
color:green;
}
p
{
color:green;
}
လို႕ ေရးထားတာကို
h1,h2,p
{
color:green;
}
လို႕ ျပင္ေရးလုိ႕ ရပါတယ္။
တူညီတာေတြကို စုစည္းေရးသားလိုက္ျခင္းအားျဖင့္ စာေၾကာင္းတိုသြားသလို file size
လည္း ေသးသြားပါတယ္။ ဒါေၾကာင့္ website loading လည္း ပိုျမန္လာပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
78
Nesting Selectors
ကၽြန္ေတာ္တုိ႕ေတြ တစ္ခါတစ္ေလ မွာ ဘယ္ ေအာက္က ဘာ ဆိုျပီး ေခၚသံုးခ်င္တာေတြ
႐ိွပါတယ္။ ဥပမာ ။။ .marked ေအာက္က p ဆိုျပီးေတာ့ေပါ့။ အဲဒါကို
ဒီလုိေရးလုိ႕ရပါတယ္။
p
{
color:blue;
text-align:center;
}
.marked
{
background-color:blue;
}
.marked p
{
color:white;
}
လို႕ ေရးထားတာက .marked ေအာက္က p tag ေတြအားလံုးကို အျဖဴေရာင္နဲ႕ ျပဆိုျပီး
ေၾကျငာလိုက္တာပါ။
CSS Dimension
CSS မွာ အရြယ္အစားေတြ ကို သတ္မွတ္ဖို႕ ေအာက္က properties ေတြကို
အသံုးျပဳႏိုင္ပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
79
Property Description Value
height ပံုေသ အျမင့္ ျဖစ္သည္။
စာေၾကာင္းမ်ားသြားလွ်င္ အျမင့္
ထပ္မတိုး သလို
စာနည္းေနရင္လည္း မေလ်ာ့ပါ။
ပံုေသ သတ္မွတ္ခ်က္ျဖစ္သည္။
auto
px
%
max-height အမ်ားဆံုး ေရာက္႐ိွခြင့္႐ိွသည့္
အျမင့္ျဖစ္သည္။
auto
px
%
max-width အမ်ားဆံုး ေရာက္႐ိွခြင့္႐ိွသည့္
အက်ယ္ျဖစ္သည္။
auto
px
%
min-height အနည္းဆံုးထားရမည့္ အျမင့္
ျဖစ္သည္။
auto
px
%
min-width အနည္းဆံုးထားရမည့္
အက်ယ္ျဖစ္သည္။
width ပံုေသ အက်ယ္ ျဖစ္သည္။
စာေၾကာင္းမ်ားသြားလွ်င္
ထပ္မက်ယ္ေတာ့ သလို
စာနည္းေနရင္လည္း မတိုပါ။
ပံုေသ သတ္မွတ္ခ်က္ျဖစ္သည္။
CSS Display and Visibility
မျမင္လိုတဲ့ selector ေတြကို display:none သို႕မဟုတ္ visibility:hidden ဆိုျပီး
ေဖ်ာက္ထားလို႕ရပါတယ္။ မျမင္ခ်င္တဲ့ စာေတြကို ေဖ်ာက္တာေတြကို အဓိက javascript နဲ႕
တြဲျပီး အသံုးျပဳပါတယ္။ ဥပမာ ။။ ပံုေတြကို button ေလးႏိွပ္လိုက္မွ ေပ်ာက္သြားတာမ်ဳိးေပါ့။
အဲဒီ အပိုင္းက css တစ္ခုတည္းနဲ႕ မရပါဘူး။ javascript ပါ တြဲ သံုးရပါတယ္။ အခုေတာ့
ကၽြန္ေတာ္ a tag နဲ႕ တြဲသံုးျပပါမယ္။
<html>
<head>
<style type="text/css">
CSS for starter , written by saturngod ( www.saturngod.net )
80
a:hover {visibility:hidden;}
</style>
</head>
<body>
<a href="http://www.saturngod.net">hover and hide</a>
</body>
</html>
ကို run တဲ့ အခါမွာ hover and hide ဆိုတာ ေပၚလာပါမယ္။ အဲဒီ ေပၚ mouse တင္လုိက္ရင္
စာ ေပ်ာက္သြားတာ ေတြ႕ရမွာပါ။
<html>
<head>
<style type="text/css">
h1.hidden {display:none;}
</style>
</head>
<body>
<h1>This is a visible heading1</h1>
<h1 class="hidden">This is a hidden heading 2</h1>
<p>Notice that the hidden heading does not take up space.</p>
</body>
</html>
ကို စမ္းၾကည့္ရင္ ဒီလို ျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
81
Block and Inline Elements
Block နဲ႕ Inline ကိုေတာ့ list ေတြနဲ႕ တြဲသံုးၾကပါတယ္။ list နဲ႕ တြဲသံုးျပမွသာ block နဲ႕ inline
ကို နားလည္ပါလိမ့္မယ္။ block ကေတာ့ block တစ္ခုလံုး အျပည့္ယူသြားတာပါ။ inline ကေတာ့
တစ္ေနရာတည္းမွာ တစ္ေၾကာင္းတည္း အေနနဲ႕ ေဖာ္ျပေပးမွာပါ။ ဥပမာ။။ menu ေတြ
လိုမ်ဳိးေပါ့။
<html>
<head>
<style type="text/css">
li{display:inline;}
</style>
</head>
<body>
<p>Display this link list as a horizontal menu:</p>
<ul>
<li><a href="/html/default.asp" target="_blank">HTML</a></li>
<li><a href="/css/default.asp" target="_blank">CSS</a></li>
<li><a href="/js/default.asp" target="_blank">JavaScript</a></li>
<li><a href="/xml/default.asp" target="_blank">XML</a></li>
</ul>
</body>
</html>
ကို run လုိက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
li ေတြကို inline သံုးထားတဲ့အတြက္ list ေတြက တစ္ေၾကာင္းတည္းမွာ ျမင္ရေနတာပါ။ default
က display:block ျဖစ္တဲ့အတြက္ တစ္ေၾကာင္းစီ ခြဲျပီး ျမင္ေနရတာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
82
HTML မွာ တုန္းက တစ္ေၾကာင္းတည္းမွာ အသံုးျပဳခ်င္လုိ႕ div အစား span ကို သံုးခဲ့တာ
မွတ္မိအံုးမယ္ ထင္ပါတယ္။ span ကို div လိုမ်ဳိး line breaking ျဖစ္သြားေအာင္ display:block
နဲ႕ ဖန္တီးလို႕ရပါတယ္။
<html>
<head>
<style type="text/css">
span
{
display:block;
}
</style>
</head>
<body>
<h2>Nirvana</h2>
<span>Record: MTV Unplugged in New York</span>
<span>Year: 1993</span>
<h2>Radiohead</h2>
<span>Record: OK Computer</span>
<span>Year: 1997</span>
</body>
</html>
ကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
83
CSS for starter , written by saturngod ( www.saturngod.net )
84
Position
CSS မွာ position က အေရးပါတဲ့ အထဲမွာ ပါပါတယ္။ Position မွာ fixed , relative , absolute
ဆိုတာေတြ ရိွပါတယ္။
Fixed Position
Fixed ဆိုတာကေတာ့ တစ္ေနရာတည္းမွာ အတည္ျဖစ္ေနတာပါ။ ဥပမာ ေျပာရရင္ေတာ့ facebook က
chat လိုမ်ဳိး ေအာက္မွာ ကပ္ေနတာမ်ဳိးေပါ့။
<html>
<head>
<style type="text/css">
p.pos_fixed
{
position:fixed;
top:10px;
right:5px;
}
p.pos_fixed2
{
position:fixed;
bottom:5px;
left:5px;
background:#453245;
color:#FFF;
}
</style>
</head>
<body>
<p class="pos_fixed">Some more text</p>
<p><b>Note:</b> IE7 and IE8 supports the fixed value only if a
!DOCTYPE is specified.</p>
CSS for starter , written by saturngod ( www.saturngod.net )
85
<p>Some text</p><p>Some text</p><p>Some text</p><p>Some text</
p><p>Some text</p><p>Some text</p><p>Some text</p><p>Some text</
p><p>Some text</p><p>Some text</p><p>Some text</p><p>Some text</
p><p>Some text</p><p>Some text</p><p>Some text</p><p
class="pos_fixed2">Bottom</p>
</body>
</html>
အဲဒီ code ေလးကို run လုိက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
windows ကို ေသးေသးထားျပီး scroll ဆြဲၾကည့္ပါ။ ဘယ္ဘက္ အေပၚက စာနဲ႕ ေအာက္ညာဘက္က
စာက ေနရာမေျပာင္းပဲ အျမဲ ကပ္ေနတာေတြ႕ပါလိမ့္မယ္။
Relative Position
Relative position ကေတာ့ လက္ရိွ ရိွေနတဲ့ position ေပၚမွာ မူတည္ျပီး ေျပာင္းလဲ ေပးတာပါ။
ေအာက္က ဥပမာ ေလးကို ၾကည့္ၾကည့္လုိက္ပါ။ သူက position absolute နဲ႕ အျမဲ
ေရာေထြးတတ္ပါတယ္။
<html>
CSS for starter , written by saturngod ( www.saturngod.net )
86
<head>
<style type="text/css">
h2.pos_left
{
position:relative;
top:-40px;
}
</style>
</head>
<body>
<h2>This is a heading with no position</h2>
<h2 class="pos_left">This heading is moved left according to its
normal position</h2>
<div><h2>Another One</h2><h2 class="pos_left">This heading is
moved left according to its normal position</h2></div>
<p>This is testing page</p>
</body>
</html>
အဲဒါေလးကို ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
87
Absolute Position
စာမ်က္ႏွာေပၚမွာ ၾကိဳက္တဲ့ ေနရာကို ေရႊ႕ခ်င္တဲ့အခါမွာ position ကို absolute ထားေပးရပါတယ္။
ျပီးရင္ top , bottom ,left,right value ေတြနဲ႕ ေရႊ႕ေပးလို႕ရပါတယ္။ ေအာက္က ဥပမာ ေလးကို
ၾကည့္ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
h2
{
position:absolute;
left:100px;
top:150px;
}
</style>
</head>
<body>
<h2>This is a heading with an absolute position</h2>
<p>With absolute positioning, an element can be placed anywhere on
a page. The heading below is placed 100px from the left of the
page and 150px from the top of the page.</p>
</body>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
88
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
အခု position relative နဲ႕ position absolute ကို ၾကည့္ရေအာင္။
<html>
<head>
<style type="text/css">
h2.abs
{
position:absolute;
left:100px;
top:0px;
}
h2.abs2 {
position:absolute;
top:0px;
right:0px;
}
div.relative {
color:#FFF;
background:#000;
position:relative;
height:200px;
}
</style>
</head>
<body>
CSS for starter , written by saturngod ( www.saturngod.net )
89
Lorem Ipsum is simply dummy text of the printing and typesetting
industry. Lorem Ipsum has been the industry's standard dummy text ever
since the 1500s, when an unknown printer took a galley of type and
scrambled it to make a type specimen book. It has survived not only five
centuries, but also the leap into electronic typesetting, remaining
essentially unchanged. It was popularised in the 1960s with the release
of Letraset sheets containing Lorem Ipsum passages, and more recently
with desktop publishing software like Aldus PageMaker including versions
of Lorem Ipsum.
<div>
<h2 class="abs">This is header</h2>
</div>
<div class="relative">
Sample Text
<h2 class="abs2">This is header</h2>
</div>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
position ကို absolute ထားလိုက္တဲ့ အခါမွာ browser ေပၚက ၾကိဳက္တဲ့ ေနရာကို ေရႊ႕လို႕ရပါတယ္။
သို႕ေပမယ့္ menu ေတြ တည္ေဆာက္တဲ့အခါမွာ ျဖစ္ျဖစ္ layout ခ်တဲ့ ေနရာ မွာ ျဖစ္ျဖစ္ div layer
ထဲက ၾကိဳက္တဲ့ ေနရာကို ပဲ ေရႊ႕ခ်င္တဲ့အခါမွာ div ကို position: relative ဆိုျပီး ေၾကျငာထားရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
90
Z-Index
Z-Index ဆိုတာကေတာ့ CSS မွာ ဘယ္သူက အေပၚမွာ ေျပာေစခ်င္လဲဆိုတာကို သတ္မွတ္တာပါ။
တနည္းေျပာရင္ တစ္ခုနဲ႕ တစ္ခုထပ္ေနတဲ့အခါ ဘယ္သူက အေပၚ ဘယ္သူက ေအာက္ဆိုျပီး
သတ္မွတ္ေပးတာပါ။
<html>
<head>
<style type="text/css">
div.below,div.upper {
position:absolute;
top:100px;
left:100px;
}
div.below {
background:#0F0;
z-index:1;
}
div.upper {
background:#F00;
left:130px;
z-index:10;
}
</style>
</head>
<body>
<div class="upper">
Sample
</div>
<div class="below">
Sample
</div>
</body>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
91
တကယ္တန္းေတာ့ ေအာက္က ေရးထားတဲ့ background အနီေရာင္ေပၚ အစိမ္းေရာင္က ဖံုးေနရမွာပါ။
သို႕ေပမယ့္ z-index ကြာတာေၾကာင့္ အနီေရာင္က အစိမ္းေရာင္ကို ဖံုးထားျပီးသား ျဖစ္သြားတာပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
92
CSS Floating
CSS Floating ဆုိတာက ဘယ္ဘက္ ကပ္မလား ညာဘက္ကမလားဆုိျပီး သတ္မွတ္ေပးတာပါ။
position absolute နဲ႕ မတူတာက သူက လက္ရိွ ရိွေနတဲ့ ေနရာကေန ညာဘက္ သြားကပ္တာပါ။
ေအာက္က code ေလးကို ၾကည့္ျပီး run ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
img
{
float:right;
}
</style>
</head>
<body>
<p>In the paragraph below, we have added an image with style
<b>float:right</b>. The result is that the image will float to the
right in the paragraph.</p>
<p>
<img src="logocss.gif" width="95" height="84" />
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
This is some text. This is some text. This is some text.
</p>
</body>
</html>
CSS for starter , written by saturngod ( www.saturngod.net )
93
အဲဒါကို browser မွာ ဒီလို ျမင္ရပါမယ္။
float ကို right ထားလိုက္တာေၾကာင့္ image က ညာဘက္ ေထာင့္ကပ္သြားတာကို ေတြ႕ရမွာပါ။
အခုေတာ့ float ကို သံုးျပီး gallery ေလး လုပ္ၾကည့္ရေအာင္။ ပံုမွန္ အားျဖင့္ img ေတြကို ေရးလိုက္ရင္
တစ္လိုင္းဆင္းျပီးေတာ့ ေပၚေနပါလိမ့္မယ္။ ဒါေၾကာင့္ float:left ဆိုျပီး အကုန္လံုးကို တစ္လိုင္းထဲ
ေပၚေအာင္ ဖန္တီးလုိက္ပါမယ္။ float left က display:inline နဲ႕ မတူတာကေတာ့ screen width
ျပည့္သြားရင္ သူ႕အလိုလို ေနာက္တစ္လိုင္း ေျပာင္းသြားေပးတာပါ။
<html>
<head>
<style type="text/css">
.thumbnail
{
float:left;
width:110px;
height:90px;
margin:5px;
}
</style>
</head>
<body>
<h3>Image Gallery</h3>
CSS for starter , written by saturngod ( www.saturngod.net )
94
<p>Try resizing the window to see what happens when the images
does not have enough room.</p>
<img class="thumbnail" src="klematis_small.jpg" width="107"
height="90">
<img class="thumbnail" src="klematis2_small.jpg" width="107"
height="80">
<img class="thumbnail" src="klematis3_small.jpg" width="116"
height="90">
<img class="thumbnail" src="klematis4_small.jpg" width="120"
height="90">
<img class="thumbnail" src="klematis_small.jpg" width="107"
height="90">
<img class="thumbnail" src="klematis2_small.jpg" width="107"
height="80">
<img class="thumbnail" src="klematis3_small.jpg" width="116"
height="90">
<img class="thumbnail" src="klematis4_small.jpg" width="120"
height="90">
</body>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
95
ေနာက္ျပီးေတာ့ float ကို ရွင္းခ်င္ရင္ေတာ့ clear:both ဆုိျပီး အသံုးျပဳပါတယ္။ ေနာက္ထပ္ code
တစ္ခုကို ထပ္ၾကည့္ရေအာင္။
<html>
<head>
<style type="text/css">
.thumbnail
{
float:left;
width:110px;
height:90px;
margin:5px;
}
.text_line
{
clear:both;
margin-bottom:2px;
}
</style>
</head>
<body>
<h3>Image Gallery</h3>
<p>Try resizing the window to see what happens when the images
does not have enough room.</p>
<img class="thumbnail" src="klematis_small.jpg" width="107"
height="90">
<img class="thumbnail" src="klematis2_small.jpg" width="107"
height="80">
<img class="thumbnail" src="klematis3_small.jpg" width="116"
height="90">
<img class="thumbnail" src="klematis4_small.jpg" width="120"
height="90">
<h3 class="text_line">Second row</h3>
<img class="thumbnail" src="klematis_small.jpg" width="107"
height="90">
CSS for starter , written by saturngod ( www.saturngod.net )
96
<img class="thumbnail" src="klematis2_small.jpg" width="107"
height="80">
<img class="thumbnail" src="klematis3_small.jpg" width="116"
height="90">
<img class="thumbnail" src="klematis4_small.jpg" width="120"
height="90">
</body>
</html>
အဲဒါကို browser မွာ ဒီလိုေပၚေနပါမယ္။
All CSS Float Properties
Property Description Value
clear float ကို ရွင္းရန္ left
right
both
none
float box ကို ေရႊ႕ရန္ left
right
none
CSS for starter , written by saturngod ( www.saturngod.net )
97
CSS for starter , written by saturngod ( www.saturngod.net )
98
CSS Pseudo Class
CSS pseudo-class ကေတာ့ အထူးသီးသန္႕ selector ေတြပါ။ ဘယ္လို ေတြလဲဆိုေတာ့ ကၽြန္ေတာ္တုိ႕
anchor မွာ သံုးခဲ့သလို a:hover , a:link တုိ႕မွာ :hover , :link တုိ႕က pseudo class ေတြပါပဲ။
First Child
first-child pseudo class ကေတာ့ ပထမဆံုး child ကို ေခၚတာပါ။ ရွင္းသြားေအာင္ code ေလးကို
ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
p:first-child
{
color:blue;
}
</style>
</head>
<body>
<p>This is some text.</p>
<p>This is some text.</p>
<p><b>Note:</b> For :first-child to work in IE8 and earlier, a
DOCTYPE must be declared.</p>
</body>
</html>
အဲဒါကို browser မွာ ဒီလို ျမင္ရပါမယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
99
ပထမဆံုး p က အျပာေရာင္နဲ႕ ေပၚေနတာကို ေတြ႕ပါလိမ့္မယ္။
ထပ္ျပီး ရွင္းသြားေအာင္ ေအာက္က code ကို ထပ္ၾကည့္ၾကည့္ပါ။
<html>
<head>
<style type="text/css">
p > i:first-child
{
color:blue;
}
</style>
</head>
<body>
<p>I am a <i>strong</i> man. I am a <i>strong</i> man.</p>
<p>I am a <i>strong</i> man. I am a <i>strong</i> man.</p>
<p><b>Note:</b> For :first-child to work in IE8 and earlier, a
DOCTYPE must be declared.</p>
</body>
</html>
အဲမွာ ပထမဆံုး i tag နဲ႕ ေရးထားတဲ့ strong က အျပာေရာင္ ျဖစ္ေနပါလိမ့္မယ္။
p>i ဆိုတာကေတာ့ p ေအာက္မွာ ရိွတဲ့ i ကို ဆိုလိုတာပါ။ p:first-child i ဆုိရင္ေတာ့ ပထမဆံုး p ရဲ႕ i
ကို ပဲ ေျပာင္းပါလိမ့္မယ္။ အဲဒါကိုေတာ့ ကိုယ္တိုင္ စမ္းၾကည့္လုိက္ပါ။
:before and :after
CSS for starter , written by saturngod ( www.saturngod.net )
100
:before နဲ႕ :after selector ေတြက content နဲ႕ တြဲျပီး အသံုးျပဳပါတယ္။ စာနဲ႕ ရွင္းျပေနရင္ နည္းနည္း
ရႈပ္ပါတယ္။ code ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
p.no1:before {
content:"Hello";
background:#000;
color:#FFF;
}
p.no2:after {
content:"good bye";
background:#000;
color:#FFF;
}
</style>
</head>
<body>
<p class="no1">
This is sample text
</p>
<p class="no2">
This is sample text
</p>
</body>
</html>
အဲဒါကုိ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
101
before ကေတာ့ မတိုင္ခင္မွာ ထပ္ျဖည့္ေပးတာေပါ့။ after ကေတာ့ ျပီးတဲ့ အခါမွာ ထပ္ျဖည့္ဖုိ႕
အတြက္ပါ။
All Pseudo Property
Property Example Description
:link a:link unvisited link ေတြ အားလံုးကို
အတြက္ selector
:visited a:visited visited link ေတြ အတြက္
selector
:active a:active active ျဖစ္တဲ့အခ်ိန္အတြက္
selector
:hover a:hover mouse hover လုပ္လိုက္တဲ့
အခ်ိန္အတြက္
:focus input:focus input မွာ focus ျဖစ္သြားတဲ့
အခ်ိန္အတြက္ selector
:first-letter p:first-letter paragraph မွာ ပထမဆံုး
စာလံုး အတြက္ selector
:first-line p:first-line <br/> မတုိင္ခင္ ပထမဆံုး line
အတြက္
:first-child p:first-child ပထမဆံုး child အတြက္
:before p:before paragraph တြင္ စာ မ စခင္
အတြက္
:after p:after paragraph တြင္ စာ ဆံုးျပီး
အတြက္
CSS for starter , written by saturngod ( www.saturngod.net )
102
Opacity
ပံုေတြ background color ေတြကို ေဖ်ာက္ျပီး ျမင္ရေအာင္ အတြက္ opacity ကို ေလ်ာ့ခ်ေပးရပါတယ္။
ေအာက္က code ေလးကို ေလ့လာၾကည့္ပါ။
<html>
<head>
<style type="text/css">
body {
background:#000;
}
div {
background:#F00;
opacity:0.5;
color:#FFF;
}
</style>
</head>
<body>
<div>
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Nullam velit nisl, aliquet vitae egestas a, fringilla quis arcu.
Sed pulvinar nunc et tortor lacinia sed elementum arcu ultricies.
Integer non dolor dolor. Vivamus lobortis sem ut nibh mattis
interdum. Proin tristique rhoncus erat vitae mollis. Ut vulputate
adipiscing nibh, sit amet imperdiet nisi adipiscing ac. Aliquam
lacinia odio quis ipsum semper aliquet. Fusce aliquet ligula
felis, non euismod enim. Quisque viverra, diam non fringilla
commodo, nisi tortor dignissim dolor, sed lacinia ante dolor sed
elit. Maecenas adipiscing purus nec urna molestie et vehicula elit
iaculis. Mauris eget elit bibendum nibh mattis sollicitudin
tristique ac purus. Vestibulum ante ipsum primis in faucibus orci
luctus et ultrices posuere cubilia Curae; Ut ultrices egestas
quam, sit amet pellentesque augue hendrerit eu.
</div>
CSS for starter , written by saturngod ( www.saturngod.net )
103
</body>
</html>
အဲဒါကို browser မွာ ဆိုရင္ ေအာက္ကလို ျမင္ေနရပါမယ္။
အနီေရာင္က opacity ေလ်ာ့ခ်ထားတဲ့အတြက္ အနက္ေရာင္ဘက္ကို ေဖာက္ျပီး ျမင္ေနရပါတယ္။
ေသခ်ာ ေအာင္ ကၽြန္ေတာ္ တို႕ background ကို image ထည့္ျပီး ၾကည့္ရေအာင္။
background image ထည့္လိုက္ရင္ အေပၚကလိုမ်ဳိး ျမင္ရပါလိမ့္မယ္။ အခု ပံုက စာပါ opacity
ေလ်ာ့သြားပါတယ္။ background တစ္ခုပဲ ေလ်ာ့ခ်င္ရင္ေတာ့ rgba ကို သံုးရပါမယ္။ ေအာက္က ဥပမာ
ေလးကို ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
body {
background:url('pattern.gif');
}
div {
background:rgba(255,0,0,0.5);
color:#FFF;
}
CSS for starter , written by saturngod ( www.saturngod.net )
104
</style>
</head>
<body>
<div>
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Nullam velit nisl, aliquet vitae egestas a, fringilla quis arcu.
Sed pulvinar nunc et tortor lacinia sed elementum arcu ultricies.
Integer non dolor dolor. Vivamus lobortis sem ut nibh mattis
interdum. Proin tristique rhoncus erat vitae mollis. Ut vulputate
adipiscing nibh, sit amet imperdiet nisi adipiscing ac. Aliquam
lacinia odio quis ipsum semper aliquet. Fusce aliquet ligula
felis, non euismod enim. Quisque viverra, diam non fringilla
commodo, nisi tortor dignissim dolor, sed lacinia ante dolor sed
elit. Maecenas adipiscing purus nec urna molestie et vehicula elit
iaculis. Mauris eget elit bibendum nibh mattis sollicitudin
tristique ac purus. Vestibulum ante ipsum primis in faucibus orci
luctus et ultrices posuere cubilia Curae; Ut ultrices egestas
quam, sit amet pellentesque augue hendrerit eu.
</div>
</body>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါမယ္။
opacity က အကုန္လံုးကို သက္ေရာက္ေစပါတယ္။ background color တစ္ခုတည္း သက္ေရာက္
ေစလိုတဲ့ အခါမွာ rgba ကို အသံုးျပဳႏုိင္ပါတယ္။ rgba ဆိုတာကေတာ့ red , green , blue , alpha ပါ။
alpha နဲ႕ opacity က အတူတူပါပဲ။ value အျမင့္ဆံုးက 1 ျဖစ္ျပီး အနိမ့္ဆံုးကေတာ့ 0 ပါ။
CSS for starter , written by saturngod ( www.saturngod.net )
105
Image Sprite
image sprite ဆိုတာကေတာ့ ပံုေတြ အမ်ားၾကီးထဲကို ပံု တစ္ပံုထဲမွာ ထည့္ထားတာပါ။ အဲဒီ
အတြက္ေၾကာင့္ ပံု ေတြ အမ်ားၾကီးအတြက္ တစ္ခါပဲ request လုပ္ရံုပါပဲ။ ျပီးမွ ပံုေတြကို ခြဲ ျပီးေတာ့
ျပန္သံုးတာေပါ့။
ဆိုတဲ့ ပံုေလးမွာ ပံု ၃ ပံုကို တစ္ခုတည္း ေပါင္းထားတာပါ။ ပံုကိုေတာ့ http://www.w3schools.com/
css/img_navsprites.gif ကေန ရယူထားပါတယ္။
အဲဒါကို အသံုးျပဳျပီး ေအာက္က code ကို ေရးလိုက္ပါမယ္။
<html>
<head>
<style type="text/css">
img.home
{
width:46px;
height:44px;
background:url(img_navsprites.gif) 0 0;
}
img.next
{
width:43px;
height:44px;
background:url(img_navsprites.gif) -91px 0;
}
</style>
</head>
<body>
<img class="home" src="img_trans.gif" width="1" height="1" />
<br /><br />
CSS for starter , written by saturngod ( www.saturngod.net )
106
<img class="next" src="img_trans.gif" width="1" height="1" />
</body>
</html>
background ကို 0 0 သံုးထားတာကို ေတြ႕မွာပါ။ left position က 0 , top position က 0 လုိ႕
ဆိုထားတာပါ။ တတိယ ပံု left position က 91px မွာ စပါမယ္။ တတိယ ပံုကို ေခၚခ်င္ေတာ့ -91px
ဆိုျပီး ေခၚလိုက္ပါတယ္။ ဒုတိယပံုကို ေခၚခ်င္ရင္ေတာ့ -47 ဆိုျပီး ေခၚလိုက္ဖုိ႕ လိုပါလိမ့္မယ္။ အဲဒါကို
browser မွာ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
အဲဒီ image ကို သံုးျပီးေတာ့ navigation ေဆာက္ၾကည့္ရေအာင္။ ေသခ်ာေအာင္ ေအာက္က example
ေလးကို ထပ္ၾကည့္လုိက္ပါ။
<html>
<head>
<style type="text/css">
#navlist{position:relative;}
#navlist li{margin:0;padding:0;liststyle:
none;position:absolute;top:0;}
#navlist li, #navlist a{height:44px;display:block;}
#home{left:0px;width:46px;}
#home{background:url('img_navsprites.gif') 0 0;}
#prev{left:63px;width:43px;}
#prev{background:url('img_navsprites.gif') -47px 0;}
#next{left:129px;width:43px;}
#next{background:url('img_navsprites.gif') -91px 0;}
</style>
CSS for starter , written by saturngod ( www.saturngod.net )
107
</head>
<body>
<ul id="navlist">
<li id="home"><a href="default.html"></a></li>
<li id="prev"><a href="css_intro.html"></a></li>
<li id="next"><a href="css_syntax.html"></a></li>
</ul>
</body>
</html>
အဲဒါကို run လိုက္ရင္ ေအာက္ကလို ျမင္ရပါလိမ့္မယ္။
ကၽြန္ေတာ္တို႕က row တစ္ခု တည္းျဖစ္ေနတဲ့အတြက္ top ကို 0px နဲ႕ ပဲ ေခၚေနပါတယ္။ တကယ္လို႕
ကၽြန္ေတာ္တုိ႕ေတြ hover effect ေတြ သံုးခ်င္တဲ့အခါမွာ row ၂ ခုကို အသံုးျပဳရင္ ရသလို ၁ ခု
တည္းမွာလည္း ရပါတယ္။ အခု top position အေၾကာင္း သိသြားေအာင္ ေအာက္က ပံုကို
အသံုးျပဳပါမယ္။
ဒုတိယ row ကေတာ့ hover လုပ္တဲ့အခါမွာ ေျပာင္းသြားဖုိ႕ပါ။ ပံုကိုေတာ့ http://
www.w3schools.com/css/img_navsprites_hover.gif ကေန ရယူႏိုင္ပါတယ္။
<html>
<head>
<style type="text/css">
#navlist{position:relative;}
#navlist li{margin:0;padding:0;liststyle:
none;position:absolute;top:0;}
CSS for starter , written by saturngod ( www.saturngod.net )
108
#navlist li, #navlist a{height:44px;display:block;}
#home{left:0px;width:46px;}
#home{background:url('img_navsprites_hover.gif') 0 0;}
#home a:hover{background: url('img_navsprites_hover.gif') 0
-45px;}
#prev{left:63px;width:43px;}
#prev{background:url('img_navsprites_hover.gif') -47px 0;}
#prev a:hover{background: url('img_navsprites_hover.gif') -47px
-45px;}
#next{left:129px;width:43px;}
#next{background:url('img_navsprites_hover.gif') -91px 0;}
#next a:hover{background: url('img_navsprites_hover.gif') -91px
-45px;}
</style>
</head>
<body>
<ul id="navlist">
<li id="home"><a href="default.html"></a></li>
<li id="prev"><a href="css_intro.html"></a></li>
<li id="next"><a href="css_syntax.html"></a></li>
</ul>
</body>
</html>
အေပၚက code မွာ hover effect အတြက္ top ေတြကို -45px ကို သံုးထားတာကို ေတြ႕ႏိုင္ပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
109
Attribute Selector
တစ္ခါတစ္ေလမွာ selector ေတြကို attribute နဲ႕ အသံုးျပဳဖို႕ လိုပါတယ္။ ဥပမာ input လိုမ်ဳိးေပါ့။ input
ရဲ႕ type ေတြမွာ textbox , password , checkbox , file , submit , image စတာေတြ ရိွတဲ့အခါမွာ
textbox ေတြ အကုန္လံုးကိုပဲ select လုပ္ခ်င္တယ္။ အဲဒီ အခါမ်ဳိးမွာ attribute selector ကို
အသံုးျပဳႏိုင္ပါတယ္။
<html>
<head>
<style type="text/css">
input[type="text"] {
background:#F00;
color:#FFF;
}
</style>
</head>
<body>
<input type="text" value="Text" />
<input type="password" value="password" />
</body>
</html>
ဆိုတာကို browser မွာ ေအာက္ကလို ျမင္ရပါမယ္။
type=”text” ျဖစ္ေနတာကိုပဲ ေျပာင္းေပးထားတာကို ေတြ႕ႏိုင္ပါတယ္။
attribute selector ကို အသံုးျပဳတဲ့အခါမွာေတာ့
[attribute_name=attribute_value]
ဆုိျပီး ေလးေထာင့္ ကြင္းနဲ႕ အသံုးျပဳႏိုင္ပါတယ္ လို႕ ေျပာရင္း နိဂံုး ခ်ဳပ္လိုက္ပါတယ္။
CSS for starter , written by saturngod ( www.saturngod.net )
110
What Next ?
HTML နဲ႕ CSS ကို ေလ့လာျပီးတဲ့အခါမွာေတာ့ ထပ္ျပီးေတာ့ javascript , jquery တို႕ကို
ေလ့လာသင့္ပါတယ္။ အခု ကၽြန္ေတာ္ ေရးထားခဲ့တဲ့ စာအုပ္ က HTML 4 နဲ႕ CSS 2 ပဲ ရိွပါေသးတယ္။
ဒါေၾကာင့္ HTML 5 နဲ႕ CSS 3 ကို လည္း ေလ့လာသင့္ပါတယ္။ HTML 5 နဲ႕ CSS 3 မွာ
ပိုမိုေကာင္းမြန္တဲ့ feature ေတြ အေျမာက္အျမား ပါဝင္ပါတယ္။ javascript , jquery တုိ႕ကို
တတ္ကြ်မ္းထားတဲ့ အခါမွာ HTML , CSS တို႕နဲ႕ တည္ေဆာက္တဲ့ website ထက္ပို ျပီးေကာင္းမြန္
ေအာင္ လုပ္လုိ႕ရလာပါတယ္။ ဒါေၾကာင့္ စာအုပ္ဖတ္ျပီးသြားတဲ့ အခါမွာ ရပ္မေနပဲ အသစ္သစ္ေတြကို
ထပ္မံေလ့လာျပီး လွပ ေကာင္းမြန္တဲ့ web site ေတြ တည္ေဆာက္ႏုိင္ၾကပါေစဗ်ာ။
CSS for starter , written by saturngod ( www.saturngod.net )
111

0 comments:

Post a Comment