Belajar CSS Transition Timing Function dan Easing

Created at by Aris Munandar

Efek transisi halus dalam desain web sering kali menjadi pembeda antara tampilan profesional dan tampilan yang terasa “kaku”. Dengan CSS transition dan easing, kamu dapat membuat perubahan visual yang lembut dan menarik perhatian tanpa harus menggunakan JavaScript. Artikel ini akan membahas secara menyeluruh tentang CSS transition timing function dan easing, serta memberikan contoh, kode, dan tips agar kamu bisa menguasai konsep ini sepenuhnya.

Baca juga: Membuat Efek Gradient Bergerak Menggunakan CSS

Apa Itu CSS Transition?

CSS transition adalah fitur dalam CSS yang memungkinkan perubahan nilai properti terjadi secara bertahap, bukan langsung. Dengan menggunakan transisi, ketika elemen berubah (misalnya saat hover), peralihan warnanya tidak langsung berubah, tetapi berjalan dengan kecepatan tertentu sesuai waktu yang ditentukan.

Contoh sederhana:

button {
    background-color: #3498db;
    transition: background-color 0.3s ease;
}

button:hover {
    background-color: #2ecc71;
}Code language: CSS (css)

Ketika pointer diarahkan ke tombol, warna biru berubah menjadi hijau secara halus berkat transition.

Properti Dasar CSS Transition

Untuk memahami transisi dengan baik, kamu harus tahu empat properti utama dalam CSS transition:

PropertiPenjelasan
transition-propertyMenentukan properti CSS mana yang akan diberi efek transisi
transition-durationMenentukan lamanya transisi berlangsung
transition-timing-functionMenentukan kecepatan perubahan (easing)
transition-delayMenentukan kapan transisi mulai berjalan

Contoh lengkap:

.card {
    transition-property: all;
    transition-duration: 0.5s;
    transition-timing-function: ease-in-out;
    transition-delay: 0s;
}Code language: CSS (css)

Atau dalam bentuk shorthand:

.card {
    transition: all 0.5s ease-in-out 0s;
}Code language: CSS (css)

Memahami Transition Timing Function (Easing CSS)

Bagian paling menarik dari transisi adalah bagaimana kecepatan perubahan terjadi. Di sinilah transition-timing-function atau easing CSS berperan.

Easing CSS menentukan laju perubahan nilai selama durasi transisi. Artinya, kamu bisa mengontrol apakah animasi dimulai cepat lalu melambat, atau sebaliknya.

Jenis-Jenis Easing di CSS

Berikut daftar fungsi easing bawaan dalam CSS:

Nilai EasingPenjelasan
easeDefault. Perubahan cepat di awal dan akhir, lambat di tengah.
linearKecepatan konstan dari awal sampai akhir.
ease-inPerubahan lambat di awal, semakin cepat di akhir.
ease-outCepat di awal, melambat di akhir.
ease-in-outGabungan antara ease-in dan ease-out.
cubic-bezier(x1, y1, x2, y2)Fungsi kustom untuk membuat pola kecepatan sendiri.

Contoh Visual Easing CSS

Contoh penggunaan beberapa timing function:

.box {
    width: 100px;
    height: 100px;
    background: #3498db;
    transition: transform 2s;
}

.box.ease       { transition-timing-function: ease; }
.box.linear     { transition-timing-function: linear; }
.box.ease-in    { transition-timing-function: ease-in; }
.box.ease-out   { transition-timing-function: ease-out; }
.box.ease-in-out{ transition-timing-function: ease-in-out; }

.box:hover {
    transform: translateX(300px);
}Code language: CSS (css)

HTML-nya:

<div class="box ease"></div>
<div class="box linear"></div>
<div class="box ease-in"></div>
<div class="box ease-out"></div>
<div class="box ease-in-out"></div>Code language: HTML, XML (xml)

Cobalah sendiri — kamu akan melihat perbedaan pola gerak yang sangat mencolok antara satu easing dan lainnya.

Menyesuaikan Easing dengan cubic-bezier()

Jika kamu ingin kontrol penuh terhadap pola kecepatan animasi, gunakan fungsi cubic-bezier(x1, y1, x2, y2).

Contoh penggunaan cubic-bezier:

Contoh:

.element {
    transition: transform 1.5s cubic-bezier(0.68, -0.55, 0.27, 1.55);
}

.element:hover {
    transform: translateY(-30px);
}Code language: CSS (css)

Nilai-nilai angka tersebut mewakili kurva bezier 4 titik kontrol yang mengatur percepatan dan perlambatan animasi. Kamu dapat membuat kurvamu sendiri dengan alat online seperti https://cubic-bezier.com.

Konsep Dasar Timing Function

Untuk memahami bagaimana easing bekerja, perhatikan bahwa fungsi timing mengontrol persentase perubahan terhadap waktu.

Misalnya:

  • ease-in: grafik cenderung lambat di awal, lalu menanjak cepat di akhir.
  • ease-out: grafik menurun cepat di awal, lalu melambat.
  • linear: grafik berbentuk garis lurus.

Setiap fungsi easing pada dasarnya menggambarkan kurva seperti ini:

ease-in       = lambat → cepat
ease-out      = cepat → lambat
ease-in-out   = lambat → cepat → lambat

Contoh CSS Transition dalam Interaksi Pengguna

Hover Efek Tombol dengan Easing

button {
    padding: 12px 24px;
    background-color: #e74c3c;
    color: white;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    transition: background-color 0.4s ease-in-out, transform 0.3s ease-in;
}

button:hover {
    background-color: #c0392b;
    transform: scale(1.1);
}Code language: CSS (css)

Efek di atas menghasilkan tombol yang membesar perlahan saat diarahkan pointer, menciptakan sensasi “responsif dan lembut”.

Card Hover dengan Shadow dan Transform

.card {
    height: 100px;
    width: 100px;
    border: 1px solid #000;
    background: #fff;
    border-radius: 8px;
    box-shadow: 0 4px 10px rgba(0,0,0,0.1);
    transition: transform 0.5s ease, box-shadow 0.5s ease;
}

.card:hover {
    transform: translateY(-10px);
    box-shadow: 0 10px 25px rgba(0,0,0,0.2);
}Code language: CSS (css)

Perpaduan transform dan ease menciptakan transisi lembut seperti efek “mengambang” saat pengguna hover.

Berikut ini adalah hasil visual dari ketiga efek diatas.

Efek Transition CSS

Menggunakan Delay dan Duration

Properti transition-duration dan transition-delay mengatur lamanya dan kapan transisi mulai.

Contoh:

.image {
    opacity: 0.5;
    transition: opacity 1s ease-in-out 0.3s;
}

.image:hover {
    opacity: 1;
}Code language: CSS (css)

Artinya:

  • Efek transisi berlangsung selama 1 detik.
  • Dimulai setelah 0.3 detik setelah hover terjadi.

Kombinasi Beberapa Properti Transition

Kamu bisa menerapkan efek transisi ke beberapa properti sekaligus.

.box {
    width: 100px;
    height: 100px;
    background: #9b59b6;
    transition: width 0.5s ease, height 0.5s ease-in, background-color 0.5s ease-out;
}

.box:hover {
    width: 120px;
    height: 120px;
    background: #8e44ad;
}Code language: CSS (css)

Menggabungkan Transition dengan Transform dan Opacity

Untuk membuat efek lebih kompleks, transisi sering digabungkan dengan transform dan opacity.

.card {
    opacity: 0.7;
    transform: scale(1);
    transition: opacity 0.4s ease, transform 0.6s ease-in-out;
}

.card:hover {
    opacity: 1;
    transform: scale(1.05);
}Code language: CSS (css)

Hasilnya: elemen terlihat “fade in” dan membesar dengan halus.

Perbedaan CSS Transition vs CSS Animation

AspekCSS TransitionCSS Animation
PemicuInteraksi pengguna (hover, click)Dijalankan otomatis
Kontrol frameTidak bisa menentukan frame spesifikBisa (menggunakan @keyframes)
SifatReaktifIndependen
KemudahanSederhanaLebih kompleks

Gunakan transition untuk efek interaktif sederhana dan animation untuk efek kompleks yang berulang.

Kesimpulan

Dengan memahami CSS transition timing function dan easing, kamu dapat membuat efek animasi yang terasa lembut, natural, dan interaktif. Penggunaan transisi bukan sekadar untuk estetika, tetapi juga meningkatkan pengalaman pengguna (UX).

Hal penting yang perlu diingat:

  • Gunakan transition: all 0.3s ease; untuk efek umum.
  • Pilih fungsi easing sesuai konteks — ease-out untuk hover, ease-in untuk muncul.
  • Gunakan cubic-bezier untuk kontrol tingkat lanjut.
  • Hindari transisi terlalu lama agar tidak mengganggu interaksi.

Dengan latihan dan eksperimen, kamu akan memahami karakter tiap timing function CSS dan bisa membuat efek transisi yang profesional seperti desainer front-end berpengalaman.

1 CSS Dasar (Pemula)

2 CSS Menengah

4 CSS Mahir

5 CSS Ahli

Comments

Congrats, you have the opportunity to be the first commenter on this article. Have questions or suggestions? Please leave a comment to start discussion.

Leave comment

Alamat email Anda tidak akan dipublikasikan. Required fields are marked *

news-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

sabung ayam online

sabung ayam online

judi bola online

sabung ayam online

judi bola online

slot mahjong ways

slot mahjong

sabung ayam online

judi bola

live casino

sabung ayam online

judi bola

live casino

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

article 138000556

article 138000557

article 138000558

article 138000559

article 138000560

article 138000561

article 138000562

article 138000563

article 138000564

article 138000565

article 138000566

article 138000567

article 138000568

article 138000569

article 138000570

article 138000571

article 138000572

article 138000573

article 138000574

article 138000575

article 138000576

article 138000577

article 138000578

article 138000579

article 138000580

article 138000581

article 138000582

article 138000583

article 138000584

article 138000585

article 138000586

article 138000587

article 138000588

article 138000589

article 138000590

article 138000591

article 138000592

article 138000593

article 138000594

article 138000595

article 138000596

article 138000597

article 138000598

article 138000599

article 138000600

article 138000601

article 138000602

article 138000603

article 138000604

article 138000605

article 138000606

article 138000607

article 138000608

article 138000609

article 138000610

article 138000611

article 138000612

article 138000613

article 138000614

article 138000615

article 208000451

article 208000452

article 208000453

article 208000454

article 208000455

article 208000456

article 208000457

article 208000458

article 208000459

article 208000460

article 208000461

article 208000462

article 208000463

article 208000464

article 208000465

article 208000466

article 208000467

article 208000468

article 208000469

article 208000470

208000446

208000447

208000448

208000449

208000450

208000451

208000452

208000453

208000454

208000455

article 228000306

article 228000307

article 228000308

article 228000309

article 228000310

article 228000311

article 228000312

article 228000313

article 228000314

article 228000315

article 228000316

article 228000317

article 228000318

article 228000319

article 228000320

article 228000321

article 228000322

article 228000323

article 228000324

article 228000325

article 228000326

article 228000327

article 228000328

article 228000329

article 228000330

article 228000331

article 228000332

article 228000333

article 228000334

article 228000335

article 238000281

article 238000282

article 238000283

article 238000284

article 238000285

article 238000286

article 238000287

article 238000288

article 238000289

article 238000290

article 238000291

article 238000292

article 238000293

article 238000294

article 238000295

article 238000296

article 238000297

article 238000298

article 238000299

article 238000300

article 238000301

article 238000302

article 238000303

article 238000304

article 238000305

article 238000306

article 238000307

article 238000308

article 238000309

article 238000310

article 238000311

article 238000312

article 238000313

article 238000314

article 238000315

article 238000316

article 238000317

article 238000318

article 238000319

article 238000320

sumbar-238000256

sumbar-238000257

sumbar-238000258

sumbar-238000259

sumbar-238000260

sumbar-238000261

sumbar-238000262

sumbar-238000263

sumbar-238000264

sumbar-238000265

sumbar-238000266

sumbar-238000267

sumbar-238000268

sumbar-238000269

sumbar-238000270

sumbar-238000271

sumbar-238000272

sumbar-238000273

sumbar-238000274

sumbar-238000275

sumbar-238000276

sumbar-238000277

sumbar-238000278

sumbar-238000279

sumbar-238000280

sumbar-238000281

sumbar-238000282

sumbar-238000283

sumbar-238000284

sumbar-238000285

sumbar-238000286

sumbar-238000287

sumbar-238000288

sumbar-238000289

sumbar-238000290

sumbar-238000291

sumbar-238000292

sumbar-238000293

sumbar-238000294

sumbar-238000295

sumbar-238000296

sumbar-238000297

sumbar-238000298

sumbar-238000299

sumbar-238000300

sumbar-238000301

sumbar-238000302

sumbar-238000303

sumbar-238000304

sumbar-238000305

sumbar-238000306

sumbar-238000307

sumbar-238000308

sumbar-238000309

sumbar-238000310

sumbar-238000311

sumbar-238000312

sumbar-238000313

sumbar-238000314

sumbar-238000315

sumbar-238000316

sumbar-238000317

sumbar-238000318

sumbar-238000319

sumbar-238000320

news-1701