2014-03-01 13:05:19 +00:00
language: css
contributors:
- ["Mohammad Valipour", "https://github.com/mvalipour"]
translators:
- ["Eka Y Saputra", "http://github.com/ekajogja"]
lang: id-id
filename: learncss-id.css
---
2014-03-03 00:00:33 +00:00
Pada mulanya, web tidak memiliki elemen visual, murni teks saja.
Tapi seiring perkembangan peramban, laman web dengan elemen visual menjadi umum.
CSS adalah bahasa standar yang ada untuk menjaga keterpisahan antara
2014-03-01 13:05:19 +00:00
konten (HTML) serta tampilan-dan-kesan laman web.
2014-03-03 00:00:33 +00:00
Singkatnya, fungsi CSS ialah menyajikan sintaks yang memampukan kita
untuk memilih elemen tertentu dalam sebuah laman HTML
dan menerapkan berbagai properti visual bagi elemen tersebut.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Seperti bahasa lainnya, CSS memiliki banyak versi.
Di artikel ini, kita fokus pada CSS2.0 - yang meskipun bukan versi termutakhir
namun paling kompatibel dan didukung secara luas.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
**CATATAN:** Lantaran keluaran dari CSS berwujud efek-efek visual,
maka untuk mempelajarinya, kita perlu mencoba berbagai hal dalam dunia olah CSS
semisal [dabblet ](http://dabblet.com/ ).
Fokus utama artikel ini ialah pada sintaks dan sejumlah tips umum.
2014-03-01 13:05:19 +00:00
```css
2014-03-03 00:00:33 +00:00
/* komentar terletak diantara sepasang tanda garis miring dan bintang,
persis seperti larik ini! */
2014-03-01 13:05:19 +00:00
/* ####################
2014-03-03 00:00:33 +00:00
## SELEKTOR
2014-03-01 13:05:19 +00:00
####################*/
2014-03-03 00:00:33 +00:00
/* Secara garis besar, statemen utama dalam CSS sangat sederhana */
selektor { properti: nilai; /* properti lainnya */ }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* selektor berfungsi untuk memilih suatu elemen dalam sebuah laman.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Kita juga bisa memilih semua elemen di sebuah halaman! */
2014-03-01 13:05:19 +00:00
* { color:red; }
/*
2014-03-03 00:00:33 +00:00
Dengan menentukan sebuah elemen seperti ini pada sebuah laman:
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
< div class = 'suatu-class class2' id = 'suatuId' attr = 'nilai' / >
2014-03-01 13:05:19 +00:00
*/
2014-03-03 00:00:33 +00:00
/* kita bisa memilih elemen berdasarkan nama class-nya */
.suatu-class { }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/*atau dengan dua class sekaligus! */
.suatu-class.class2 { }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* atau dengan nama tag-nya */
2014-03-01 13:05:19 +00:00
div { }
2014-03-03 00:00:33 +00:00
/* atau id-nya */
#suatuId { }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* atau - jika ada - dengan attribute-nya! */
2014-03-01 13:05:19 +00:00
[attr] { font-size:smaller; }
2014-03-03 00:00:33 +00:00
/* atau jika attribute tersebut memiliki nilai spesifik */
[attr='nilai'] { font-size:smaller; }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* dibuka dengan sebuah nilai*/
[attr^='nil'] { font-size:smaller; }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* atau ditutup dengan nilai */
[attr$='ai'] { font-size:smaller; }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* atau bahkan disisipi nilai */
[attr~='la'] { font-size:smaller; }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* dan yang lebih penting lagi, kita bisa mengombinasikannya sekaligus
dengan syarat tidak ada spasi diantara selektor-selektor. sebab adanya spasi
akan membuat selektor itu memiliki makna yang berbeda.*/
div.suatu-class[attr$='ai'] { }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* kita juga bisa memilih sebuah elemen berdasarkan posisi elemen induknya.*/
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/*sebuah elemen yang merupakan anak langsung dari elemen induk (diseleksi dng
cara yang sama) */
div.suatu-induk > .-suatu-class {}
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* atau salah satu induk elemennya dalam hirarki elemen */
/* berikut ini dimaksudkan pada elemen manapun dengan class "class-entah" dan
merupakan anak elemen dari suatu div dengan class "induk-entah" PADA LEVEL
HIRARKI MANAPUN */
div.suatu-induk .suatu-class {}
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* peringatan: selektor yang sama jika tanpa ada spasi akan bermakna lain.
misalnya? */
div.suatu-induk.suatu-class {}
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* kita juga bisa memilih sebuah elemen berdasarkan saudara elemen yang muncul
tepat sebelumnya */
.aku-muncul-tepat-sebelum + .elemen-ini { }
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/*atau saudara elemen manapun yang pernah muncul selang beberapa elemen
sebelumnya */
.aku-pernah-muncul-sebelum ~ .elemen-ini {}
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* Ada beberapa pseudo-class yang memampukan kita memilih suatu elemen
berdasarkan perilaku lamannya (bukan struktur lamannya) */
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* semisal ketika sebuah elemen ditimpa hover (pointer mouse) */
2014-03-01 13:05:19 +00:00
:hover {}
2014-03-03 00:00:33 +00:00
/* atau link yang sudah pernah diklik*/
2014-03-01 13:05:19 +00:00
:visited {}
2014-03-03 00:00:33 +00:00
/* atau link yang belum pernah diklik*/
2014-03-01 13:05:19 +00:00
:link {}
2014-03-03 00:00:33 +00:00
/* atau elemen input yang menjadi fokus */
2014-03-01 13:05:19 +00:00
:focus {}
/* ####################
2014-03-03 00:00:33 +00:00
## PROPERTI
2014-03-01 13:05:19 +00:00
####################*/
2014-03-03 00:00:33 +00:00
selektor {
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* Unit */
width: 50%; /* dalam persen */
font-size: 2em; /* angka kali jumlah font-size saat ini */
width: 200px; /* dalam pixel */
font-size: 20pt; /* dalam point */
width: 5cm; /* dalam centimeter */
width: 50mm; /* dalam milimeter */
width: 5in; /* dalam inci */
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* Warna */
background-color: #F6E ; /* dalam short hex */
background-color: #F262E2 ; /* dalam format long hex */
background-color: tomato; /* warna yang sudah punya konvensi nama */
background-color: rgb(255, 255, 255); /* dalam rgb */
background-color: rgb(10%, 20%, 50%); /* dalam persen rgb */
background-color: rgba(255, 0, 0, 0.3); /* dalam rgb semi-transparan*/
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* Gambar */
background-image: url(/folder-gambar/image.jpg);
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
/* Font */
2014-03-01 13:05:19 +00:00
font-family: Arial;
2014-03-03 00:00:33 +00:00
font-family: "Courier New"; /* jika nama font memiliki spasi,
ia diketik dalam tanda petik ganda */
font-family: "Courier New", Trebuchet, Arial; /* jika font pertama tidak
ditemukan, peramban menggunakan font berikutnya,
demikian secara berturut-turut */
2014-03-01 13:05:19 +00:00
}
```
2014-03-03 00:00:33 +00:00
## Penggunaan
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Simpan semua CSS yang hendak kita pakai dengan ekstensi `.css` .
2014-03-01 13:05:19 +00:00
```xml
2014-03-03 00:00:33 +00:00
<!-- kita harus menautkan file css itu ke laman di bagian <head>: -->
< link rel = 'stylesheet' type = 'text/css' href = 'folder/namafile.css' / >
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
<!-- kita juga bisa mengetik CSS secara inline di dalam markup.
Namun, sebisa mungkin metode ini dihindari. -->
2014-03-01 13:05:19 +00:00
< style >
2014-03-03 00:00:33 +00:00
selektor { properti:nilai; }
2014-03-01 13:05:19 +00:00
< / style >
2014-03-03 00:00:33 +00:00
<!-- atau langsung mengetik properti CSS pada sebuah elemen.
Metode ini harus dihindari sebisa mungkin. -->
< div style = 'properti:nilai;' >
2014-03-01 13:05:19 +00:00
< / div >
```
2014-03-03 00:00:33 +00:00
## Prioritas
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Kita tahu bahwa sebuah elemen bisa dipilih dengan lebih dari satu selektor,
serta bisa diberi lebih dari satu properti.
Dalam kasus seperti ini, hanya salah satu properti saja yang akan diterapkan
pada elemen dengan prioritas tertentu.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Dengan susunan CSS:
2014-03-01 13:05:19 +00:00
```css
2014-03-03 00:00:33 +00:00
2014-03-01 13:05:19 +00:00
/*A*/
2014-03-03 00:00:33 +00:00
p.class1[attr='nilai']
2014-03-01 13:05:19 +00:00
/*B*/
p.class1 {}
/*C*/
p.class2 {}
/*D*/
p {}
/*E*/
2014-03-03 00:00:33 +00:00
p { properti: nilai !important; }
2014-03-01 13:05:19 +00:00
```
2014-03-03 00:00:33 +00:00
dan susunan markup:
2014-03-01 13:05:19 +00:00
```xml
2014-03-03 00:00:33 +00:00
< p style = '/*F*/ properti:nilai;' class = 'class1 class2' attr = 'nilai' >
2014-03-01 13:05:19 +00:00
< / p >
```
2014-03-03 00:00:33 +00:00
Maka prioritas penerapan style-nya ialah sbb.:
2014-03-05 09:39:26 +00:00
Ingat, penerapan ini untuk masing-masing **properti** ,
2014-03-03 00:00:33 +00:00
bukan keseluruhan larik.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
* `E` prioritas pertama sebab ada kata `!important` .
Dianjurkan untuk menghindari kata ini jika tidak benar-benar perlu.
* `F` prioritas kedua sebab ia diketik secara inline.
* `A` prioritas ketiga sebab selektor ini lebih spesifik dibanding yang lain.
lebih spesifik = lebih banyak unsur selektor. contoh ini punya 3 unsur:
1 tagname `p` + 1 nama class `class1` + 1 attribute `attr='nilai'`
* `C` prioritas berikutnya sebab meski sama spesifik dengan `B` namun
ia muncul lebih akhir.
* Lalu `B`
* dan terakhir baru `D` .
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
## Kompatibilitas
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
Sebagian besar fitur dalam CSS2 (dan lambat laun juga CSS3) kompatibel dengan
semua peramban dan perangkat. Namun selalu vital untuk memastikan kompatibilitas
unsur dan nilai yang kita ketikkan dalam CSS dengan peramban yang ditargetkan.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
[QuirksMode CSS ](http://www.quirksmode.org/css/ ) ialah salah satu sumber terbaik untuk memeriksa kompatibilitas CSS dan peramban.
2014-03-01 13:05:19 +00:00
2014-03-03 00:00:33 +00:00
## Referensi Lanjut
2014-03-01 13:05:19 +00:00
* [Understanding Style Precedence in CSS: Specificity, Inheritance, and the Cascade ](http://www.vanseodesign.com/css/css-specificity-inheritance-cascaade/ )
* [QuirksMode CSS ](http://www.quirksmode.org/css/ )
* [Z-Index - The stacking context ](https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Understanding_z_index/The_stacking_context )