Bedah Satuan CSS


Oleh Afrian Junior (afrianjunior)



Afrian Junior

Gendut


http://afrianjunior.gi...


Jika pada praktek sehari-hari kita hanya menggunakan satuan % dan px, namun kali ini saya akan membahas penggunaan berbagai satuan yang tepat yang mungkin belum diketahui.

Satuan % (Persentase)

Persentase adalah satuan yang tidak menghitung berdasarkan ukuran elemen itu sendiri namun perbandingan dengan induk elemennya.

Biasanya digunakan dalam hal penentuan ukuran kolom (Grid System), mari kita intip Grid System dari beberapa Framework CSS:

Semantic UI

  .ui[class*="six column"].grid > .row > .column,
  .ui[class*="six column"].grid > .column:not(.row) {
    width: 16.66666667%;
  }

Bootstrap

  .col-xs-6 {
    width: 50%;
  }

Namun satuan ini juga baik digunakan dalam penentuan ukuran header atau h1, h2, h3, dst. dalam beberapa kasus, seperti ingin mempermudah pengerjaan situs yang responsif.

Satuan px (Pixel)

Ini adalah satuan yang sering digunakan oleh mayoritas programmer, namun tahukah? bahwa satuan ini hanya cocok digunakan oleh elemen yang berukuran akurat, tidak terpengaruh oleh elemen disekitarnya atau induknya.

Satuan rem dan em

Satuan rem dan em bisa dikatakan 16 kali dari satuan px, jadi 1rem/em = 16px, namun pada satuan em bisa bergantung pada font-size, misalnya induk elemen memiliki property font-size 14px dan anaknya memiliki property font-size: 1.6em, maka hasil yang akan ditampilkan adalah 14px * 1.6em = 22.4px.

Salah satu contoh kasus yang satuan em terasa sangat bermanfaat adalah pada padding untuk elemen yang font-sizenya mudah berubah-ubah, contoh seperti :

  .button{
    font-size: 1em;
    padding: 5em 10em;
  }

Dikarenakan induk yang mempunyai property font-size dari element .button tidak ada, maka property font-size bernilai 1em = 16px, namun pada padding 5em dan 10em terpengaruh oleh nilai dari font-size, jadi 5em * 16px = 80px, dan 10em * 16px = 160px.

Tapi tidak dengan satuan rem, rem satuan yang tidak terpengaruh oleh font-size, em bisa dikatakan pewaris dari rem yang berarti "r" adalah "root".

Satuan vw dan vh

Satuan ini disebut viewport, satuan ini adalah cara terbaik untuk membuat elemen responsif, kenapa bisa?

Hampir sama dengan % atau persentase, namun persen tidak bisa menentukan height, beda dengan vw dan vh, vw artinya viewport width dan vh artinya viewport height.

Satuan ini bergantung pada induk elemennya, jika induk elemen mempunyai ukuran 300px x 400px maka 1vh darinya adalah 400 * 1/100 = 4px dan jika 100vh artinya adalah height yang kita tentukan 100% dari height induknya.

Jika induk dari element adalah 100% atau tak terhingga, maka 100vh bergantung pada ukuran layar.

  body{
    height: 100%;
  }
  body .screen.cover{
    height: 100vh;
  }

Teknik ini sangat bermanfaat jika kita ingin membuat fullscreen elemen, dan saya sangat sering menggunakannya terutama membuat cover untuk front page.

Satuan vmin dan vmax

Satuan ini mirip dengan vw dan vh, bedanya jika kita menentukan 100vmin satuan ini akan bergantung pada induk dengan ukuran terendah, bingung?

Misalnya induk elemen memiliki ukuran 1000px x 1200px, jika anak elemen memakai :

  .anak{
    height: 100vmin;
    width: 100vmin;
  }

Maka hasil yang akan ditampilkan seperti :

  .anak{
    height: 1000px;
    width: 1000px;
  }

Begitu juga sebaliknya.

Satuan ex dan ch

Satuan ini mirip dengan rem dan em, bedanya 1ex/ch = 8px, namun satuan ini tidak hanya bergantung pada font-size tapi juga bergantung pada font-family agar ukurannya lebih spesifik.

 

Kesimpulannya adalah

Bahwa mengetahui detil dari setiap satuan pada css sangat penting demi kualitas produk yang kita buat, semoga bermanfaat!

 

Original Post CodePolitan.com - Bedah Satuan CSS by Afrian Junior (Saya Sendiri)

Level artikel ini adalah beginner.
Dituliskan oleh Afrian Junior (afrianjunior) pada 29 Mei 2016 dan telah dibaca sebanyak 4642 kali.
Tag: bedah satuan css, css3 unit tips, px or em

Beri Jempol · 6 jempol

berlangganan komentar



Komentar:

kocortowap
103
0
· 8 tahun, 5 bulan yang lalu · 1 jempol

Gan satuan cm dan pt bisa nggak untuk css?

ganis
198
841
· 8 tahun, 5 bulan yang lalu · 0 jempol

@kocortowap

bisa gan, tapi gak direkomendasikan. Sebaiknya gunakan itu saat ingin ngeprint aja.

Silahkan masuk untuk menulis artikel atau komentar.



Artikel Lainnya


Ganis

8 Juni 2016

Tutorial Instalasi Sertifikat TLS/SSL Gratis untuk Website Anda

Ada yang baru di CodeSaya yaitu kami baru saja memasang sertifikat TLS/SSL untuk meningkatkan keamanan bagi pengguna kami. Sekarang semua akses ke CodeSaya haruslah melalui HTTPS. Penggunaan HTTPS artinya ...

Lanjutkan membaca

11 menit bacaan · advanced



POST Data with CURL to Https

// initialisasi variable yg dibutuhkan
$url = "http://www.domainServer.com";
$message = "This is message content";

// kirim data ke server dengan menggunakan function send($url, $message)
echo send($url, $message);

// fungsi yg ...

Lanjutkan membaca

1 menit bacaan · advanced