Cascading Style Sheets: Perbedaan antara revisi

Konten dihapus Konten ditambahkan
Tidak ada ringkasan suntingan
Tag: Suntingan perangkat seluler Suntingan peramban seluler Suntingan seluler lanjutan
 
(6 revisi perantara oleh 4 pengguna tidak ditampilkan)
Baris 1:
{{infoboxInfobox file format
| name = Cascading Style Sheets (CSS)
| extension = .css
| logoicon = [[Berkas:CSS3 logo and wordmark.svg|100px]]
| icon_size = 120px
| mime = text/css
| iconcaption = Logo resmi versi terbaru, [[#CSS 3|CSS 3]]
| owner = [[World Wide Web Consortium]]
| screenshot = [[File:Пример кода на CSS.jpg|200px]]
| genre = [[Bahasa lembar gaya]]
| caption = Contoh dari [[kode sumber]] CSS
| standard = [http://www.w3.org/TR/CSS1 Level 1 (Recommendation)]{{br}}[http://www.w3.org/TR/CSS2/ Level 2 (Recommendation)]{{br}}[http://www.w3.org/TR/CSS21/ Level 2 Revision 1 (Candidate Recommendation)]
| mime = text/css
| uniform type = public.css
| ownerdeveloper = [[World Wide Web Consortium]] (W3C)
| owner =
| genre = [[Bahasa lembar gaya]]
| released = {{release date and age|1996|12|17|df=y}}
| latest_release_version = CSS 2.1 : Level 2 Revision 1
| latest_release_date = {{release date and age|2016|4|12|df=y}}
| container_for = Aturan gaya untuk [[elemen HTML]] (tag)
| contained_by = [[HTML|Dokumen HTML]]
| standard = [http://www.w3.org/TR/CSS1 Level 1 (RecommendationRekomendasi)]{{br}}[http://www.w3.org/TR/CSS2/ Level 2 (RecommendationRekomendasi)]{{br}}[http://www.w3.org/TR/CSS21/ Level 2 Revision 1 (CandidateRekomendasi Recommendationkandidat)]
| open = Yes
| url = {{URL|https://www.w3.org/TR/CSS/#css}}
}}
'''Cascading Style Sheet''' ('''CSS''') merupakan aturan untuk mengatur beberapa komponen dalam sebuah web sehingga akan lebih terstruktur dan seragam. CSS bukan merupakan [[bahasa pemrograman]].
 
'''Cascading Style Sheet''' ('''CSS''') merupakan aturan untuk mengatur beberapa komponen dalam sebuah web sehingga akan lebih terstruktur dan seragam. CSS bukan merupakan bahasa pemrograman.
 
Sama halnya ''styles'' dalam [[aplikasi]] pengolahan kata seperti [[Microsoft Word]] yang dapat mengatur beberapa ''style'', misalnya ''heading'', ''subbab'', ''bodytext'', ''footer'', ''images'', dan ''style'' lainnya untuk dapat digunakan bersama-sama dalam beberapa berkas (''[[file]]'').<ref name="Slamet">Slamet Riyanto, ''Membuat Web Portal Multi Bahasa Jomla 1.5X + CD'', halaman 236. Elex Media Komputindo.</ref> Pada umumnya CSS dipakai untuk memformat tampilan halaman web yang dibuat dengan [[bahasa]] [[HTML]] dan [[XHTML]].<ref name="Slamet"/>
Baris 34 ⟶ 46:
Bagian pertama sebelum tanda '{}' dinamakan ''selector'', sedangkan yang diapit oleh '{}' disebut ''declaration'' yang terdiri dari ''dua'' unsur, yaitu ''property'' dan ''value''. ''Selector'' dalam pernyataan di atas adalah h1, sedangkan ''color'' adalah ''property'', dan #0789de adalah ''value.''<ref>Untung Julianto, ''Modifikator Blogger + CD'', halaman 22. Elex Media Komputindo.</ref>
 
''Selain itu ada tiga metode penulisan CSS atribut pada CSS, yaitu:''<ref name="css_html"/>
 
=== Inline Style Sheet ===
Baris 286 ⟶ 298:
}
</syntaxhighlight>
 
=== Descendant Selector ===
''Descendant selector'' merupakan cara penulisan CSS dengan memanggil semua elemen yang merupakan turunan dari elemen tertentu. <ref>{{Cite web|title=Descendant Combinator - CSS: Cascading Style Sheets {{!}} MDN|url=https://developer.mozilla.org/en-US/docs/Web/CSS/Descendant_combinator|website=developer.mozilla.org|language=en-US|access-date=2024-09-03}}</ref><syntaxhighlight lang="css" line="1">
/* Memanggil elemen <p> di dalam elemen <div> */
div p {
font-size: 12px;
}
</syntaxhighlight>
 
=== Child Selector ===
''Child selector'' merupakan cara penulisan CSS dengan memilih semua elemen yang merupakan anak langsung dari elemen tertentu. <ref>{{Cite web|title=Child Combinator - CSS: Cascading Style Sheets {{!}} MDN|url=https://developer.mozilla.org/en-US/docs/Web/CSS/Child_combinator|website=developer.mozilla.org|language=en-US|access-date=2024-09-03}}</ref>
 
Contoh:
<syntaxhighlight lang="html" line="1">
<!DOCTYPE html>
<html>
<head>
<title>Page Title</title>
<style>
div > p {
font-size: 12px;
}
</style>
</head>
<body>
<div>
<p> Teks 1 di dalam div. </p>
<p> Teks 2 di dalam div.</p>
<section>
<p> Teks 3 di section tetapi merupakan turunan dari div </p>
</section>
<p> Teks 4 di dalam div </p>
</div>
<p>Teks 5 tidak di dalam div.</p>
</body>
</html>
</syntaxhighlight>
 
Ini akan menghasilkan teks yang berada langsung di elemen <code><nowiki><div></nowiki></code> akan dirender dengan font berukuran 12 px, sedangkan teks yang tidak berada di dalam elemen <code><nowiki><div></nowiki></code> atau berada di elemen lain tetapi merupakan turunan dari elemen <code><nowiki><div></nowiki></code>, tetap memiliki ukuran font yang normal.
 
== Dukungan dari peramban web ==
Masing-masing peramban web menggunakan [[mesin tata letak]] yang berbeda. Contohnya Firefox menggunakan [[Gecko]] sebagai mesin tata letaknya dan Chromium menggunakan [[Blink (mesin browser)|Blink]] sebagai mesin tata letaknya. Dukungan untuk fitur CSS dari setiap mesin tata letak terkadang sering tidak konsisten. Beberapa teknik pun bermunculan untuk menggunakan suatu fitur CSS ke peramban web yang tidak mendukung fitur tersebut (biasa disebut ''CSS hack''). Adopsi fitur CSS baru dapat terhambat oleh kurangnya dukungan dari peramban-peramban web besar. Contohnya fitur <code>cross-fade()</code> telah didukung oleh Chrome dan Safari namun sampai tahun 2021 masih belum didukung oleh Firefox.<ref>{{Cite web|title=Can I use... Support tables for HTML5, CSS3, etc|url=https://caniuse.com/?search=cross%20fade|website=caniuse.com|access-date=2021-02-24}}</ref>
 
Beberapa pengembang web biasanya memeriksa terlebih dahulu dukungan untuk suatu fitur CSS, terutama untuk fitur CSS baru. Beberapa situs web berikut dapat membantu seperti [https://caniuse.com CanIUse] dan [https://developer.mozilla.org Mozilla Developer Network]. CSS 3 memiliki fitur kueri, yang memberikan arahan <code>@supports</code> yang akan memungkinkan pengembang menargetkan peramban web dengan dukungan untuk fungsionalitas tertentu langsung di dalam CSS mereka.<ref>{{Cite web|title=Using Feature Queries in CSS – Mozilla Hacks - the Web developer blog|url=https://hacks.mozilla.org/2016/08/using-feature-queries-in-css|website=Mozilla Hacks – the Web developer blog|language=en-US|access-date=2021-02-24}}</ref> CSS yang tidak didukung oleh suatu peramban web kadang-kadang bisa ditambal menggunakan [[polyfill]], yang merupakan potongan kode [[JavaScript]] yang dirancang untuk memberikan dukungan untuk peramban web terhadap suatu fitur yang sebelumnya tidak didukung. Solusi ini dapat menambah kerumitan pada proyek pengembangan, dan akibatnya, perusahaan sering kali menentukan daftar versi peramban web yang akan dan tidak akan mereka dukung.
 
== Penggunaan CSS dalam perangkat lunak lain ==
CSS dahulunya dibuat hanya untuk mempercantik halaman web. Namun, seiring perkembangan waktu CSS mulai diadopsi oleh perangkat lunak lain.
 
[[GTK]] adalah peralatan gawit [[lintas platform]] yang menggunakan CSS untuk memberi gaya pada setiap widget. GTK sering digunakan untuk membuat program Linux. GTK memperkenalkan API Tema baru dengan menggunakan CSS pada pembaharuan besar GTK versi 3.<ref>{{Cite web|title=February 2011 – GTK Development Blog|url=https://blog.gtk.org/2011/02/|language=en-US|access-date=2021-02-25}}</ref>
 
[[Qt]] merupakan toolkit widget dan biasa dipakai untuk membuat aplikasi lintas platform. Qt juga menggunakan CSS untuk mengkonfigurasi tema.