Regular Expression (Regex) JavaScript Lengkap

Created at by Aris Munandar

Apakah kamu pernah ingin mencari pola tertentu di dalam teks, memvalidasi input form, atau memproses data string dengan cepat di JavaScript? Jika iya, Regular Expression atau yang sering disingkat Regex adalah alat yang tepat untuk kamu pelajari. Regex memungkinkan kamu menemukan, memeriksa, dan memanipulasi teks dengan cara yang jauh lebih efisien dibandingkan menggunakan logika string biasa.

Dalam artikel ini, kita akan membahas Regex JavaScript secara lengkap, mulai dari dasar-dasar, metode populer seperti test, match, replace, hingga penggunaan regex untuk validasi email, nomor telepon, password, dan berbagai kasus praktis lainnya. Panduan ini dibuat langkah demi langkah, cocok untuk pemula maupun pengembang web yang ingin memperdalam kemampuan pattern matching dan optimasi regex di proyek nyata.

Baca juga: Error Handling di JavaScript: Try, Catch, Finally

Pengenalan Regular Expression

Pengenalan Regular Expression (Regex) adalah langkah pertama untuk memahami bagaimana pola teks bekerja dalam JavaScript. Regex merupakan sebuah pola karakter yang digunakan untuk mencari, mencocokkan, dan memanipulasi string dengan cara yang efisien. Dibandingkan metode pencarian teks biasa, regex menawarkan fleksibilitas dan kekuatan yang jauh lebih besar—mulai dari pencarian sederhana hingga validasi input kompleks seperti email, nomor telepon, dan password.

Dalam JavaScript, regular expression sudah terintegrasi secara native, sehingga penggunaannya sangat mudah dan tidak memerlukan library tambahan. Materi pengenalan ini akan membahas apa itu regex, bagaimana sejarahnya digunakan dalam berbagai bahasa pemrograman, keunggulannya di JavaScript, hingga contoh studi kasus pencarian teks. Dengan memahami dasar pengenalan regex, kamu akan mampu menggunakan pattern matching dengan lebih percaya diri dan efisien saat membangun aplikasi web modern.

1. Apa itu Regular Expression

Regular Expression atau Regex adalah sebuah pola (pattern) yang digunakan untuk mencari, mencocokkan, dan memanipulasi teks. Dalam JavaScript, regex sangat berguna untuk memvalidasi input, menemukan karakter tertentu, memfilter data, hingga melakukan transformasi teks dengan cara yang jauh lebih efisien dibandingkan metode string biasa. Regex bekerja dengan cara mencocokkan pola tertentu pada string, seperti huruf, angka, simbol, atau kombinasi kompleks.

Dalam pengembangan web modern, regex menjadi salah satu alat penting karena mampu menghemat banyak waktu dan baris kode. Dengan satu pola regex, kamu dapat menyelesaikan tugas yang biasanya membutuhkan kondisi if bertingkat atau loop yang panjang.

2. Sejarah dan penggunaan regex di berbagai bahasa pemrograman

Regular Expression pertama kali diperkenalkan pada tahun 1950-an oleh ilmuwan bernama Stephen Cole Kleene, yang mengembangkan teori matematika tentang pola simbolik. Konsep ini kemudian diadopsi ke dunia pemrograman dan digunakan dalam berbagai utilitas sistem seperti grep, sed, dan awk.

Saat ini, regex digunakan secara luas di berbagai bahasa pemrograman populer seperti:

  • JavaScript
  • Python
  • PHP
  • Java
  • C#
  • Ruby
  • Perl (bahasa yang dikenal sangat kuat dalam regex)

Meskipun sintaks regex bersifat universal, beberapa bahasa memiliki fitur tambahan atau variasi kecil. Namun secara keseluruhan, dasar penggunaannya tetap sama: membantu developer mengolah teks secara cepat dan efisien.

3. Keunggulan menggunakan regex di JavaScript

JavaScript memiliki dukungan bawaan (native) untuk Regular Expression melalui RegExp object, sehingga penggunaannya sangat fleksibel dan mudah diintegrasikan ke berbagai fungsi string. Berikut beberapa keunggulan utama menggunakan regex di JavaScript:

  1. Native support
    Tidak perlu menginstal library tambahan, cukup gunakan /pattern/ atau new RegExp().

  2. Integrasi kuat dengan metode string
    Regex dapat digunakan langsung di method seperti match(), replace(), search(), dan split().

  3. Performa tinggi
    Regex memungkinkan operasi pencarian dan validasi dilakukan lebih cepat dibandingkan logika manual.

  4. Lebih ringkas dan efisien
    Alih-alih menulis banyak kondisi, cukup gunakan satu pola regex untuk hasil yang sama.

  5. Cocok untuk validasi input modern
    Mulai dari email, password, nomor telepon, hingga format tanggal.

Dengan berbagai keunggulan ini, regex menjadi alat yang sangat penting bagi developer JavaScript—baik backend, frontend, maupun full stack.

4. Studi kasus sederhana: pencarian teks

Salah satu penggunaan paling dasar dari regex adalah mencari teks. Misalnya, kamu ingin mencari apakah sebuah kata muncul dalam sebuah kalimat. Dengan regex, ini bisa dilakukan dalam satu baris:

const text = "Belajar regex di JavaScript memang menyenangkan!";
const pattern = /regex/;

console.log(pattern.test(text)); // trueCode language: JavaScript (javascript)

Contoh lain: mencari semua huruf vokal dalam sebuah string.

const kalimat = "Regular Expression sangat berguna!";
const vokal = kalimat.match(/[aeiou]/gi);

console.log(vokal);
// Output: ["e", "u", "a", "E", "e", "i", "o", "a", "a", "e", "u", "a"]Code language: JavaScript (javascript)

Penggunaan sederhana ini menggambarkan kekuatan regex sebagai alat pencarian dan analisis teks dengan cara yang cepat dan efisien.

Sintaks Dasar Regex di JavaScript

Sintaks adalah fondasi utama dalam memanfaatkan regular expression JavaScript. Untuk dapat membuat pola yang akurat dan efisien, kamu perlu memahami cara membuat regex, karakter dasar yang digunakan, hingga bagaimana flags bekerja dalam proses pencarian. Bagian ini akan membantu kamu memahami konsepnya secara bertahap.

1. Membuat Regex: Literal vs Constructor

Dalam JavaScript, regex dapat dibuat dengan dua cara:

1. Regex Literal

Cara paling umum dan simpel.

const regex = /hello/;Code language: JavaScript (javascript)

Keunggulannya:

  • Lebih mudah dibaca
  • Lebih cepat dituliskan
  • Ideal untuk pola statis

2. Regex Constructor

Digunakan saat pola regex bersifat dinamis (dibuat dari variable).

const pattern = "hello";
const regex = new RegExp(pattern, "g");Code language: JavaScript (javascript)

Keunggulannya:

  • Mudah untuk membuat pola runtime
  • Dapat menggabungkan nilai variable ke dalam regex

Namun syntax-nya sedikit lebih panjang, dan kamu perlu melakukan escape ekstra saat menggunakan karakter khusus.

2. Karakter Biasa dan Meta Character

Regex terdiri dari dua jenis karakter:

1. Karakter Biasa

Digunakan untuk mencocokkan karakter apa adanya. Contoh:

  • a → mencari huruf “a”
  • cat → mencari kata “cat”

2. Meta Character (Karakter Khusus)

Digunakan untuk memberi arti tertentu pada pola regex.

Contoh meta character penting:

MetaArti
.Mencocokkan sembarang 1 karakter
\dDigit 0–9
\wAlphanumeric + underscore
\sWhitespace
^Awal string
$Akhir string
*0 atau lebih pengulangan
+1 atau lebih pengulangan
?Opsional (0 atau 1 kali)
[]Character set
()Grouping / capturing

Meta character inilah yang membuat regex JavaScript begitu fleksibel dan kuat dalam pattern matching.

3 Flags Regex (g, i, m)

Flags adalah penanda tambahan yang mengubah perilaku regex.

1. g — global

Mencari semua hasil, bukan hanya satu.

"hello hello".match(/hello/g);Code language: JavaScript (javascript)

2. i — case insensitive

Mengabaikan huruf kapital atau kecil.

/hello/i.test("HELLO"); // trueCode language: JavaScript (javascript)

3. m — multiline

Memperlakukan ^ dan $ sebagai awal/akhir setiap baris, bukan keseluruhan string.

/^hi/m.test("hello\nhi"); // trueCode language: JavaScript (javascript)

Flags dapat digabungkan:

/hello/gi;

4. Escape Character dan Special Character

Karena regex memiliki banyak karakter khusus, kamu perlu melakukan escape menggunakan \ ketika ingin mencocokkannya secara literal.

Contoh karakter yang harus di-escape:

. * + ? ^ $ { } ( ) | [ ] \

Contoh penggunaan:

const regex = /\./; // mencari titik "."Code language: JavaScript (javascript)

Jika menggunakan constructor:

const regex = new RegExp("\\.");Code language: JavaScript (javascript)

Karena constructor juga menggunakan escape string JavaScript, kamu harus menggandakan backslash.

Metode Regex di JavaScript

Setelah memahami sintaks dasar regex di JavaScript, langkah berikutnya adalah mempelajari berbagai metode bawaan JavaScript yang sering digunakan bersama regular expression. Metode-metode ini adalah alat utama yang akan kamu pakai untuk melakukan pencocokan pola, mencari teks, memecah string, hingga memodifikasi teks.

Di bagian ini, kita akan membahas semua metode penting yang wajib dikuasai:

  • test()
  • match()
  • replace()
  • search()
  • split()

Setiap metode memiliki fungsi berbeda dan sangat berguna dalam berbagai situasi pemrograman.

1. test() → Cek Pattern

Metode test() digunakan untuk mengetahui apakah sebuah string cocok dengan pola regex. Metode ini akan mengembalikan:

  • true jika ada kecocokan
  • false jika tidak ada kecocokan

Contoh:

const regex = /hello/;
console.log(regex.test("hello world")); // trueCode language: JavaScript (javascript)

Cocok digunakan untuk validasi sederhana, seperti:

  • cek apakah input mengandung angka
  • cek apakah password mengandung huruf besar
  • cek apakah username valid

Contoh validasi angka:

const numberCheck = /\d/;
console.log(numberCheck.test("aris123")); // trueCode language: JavaScript (javascript)

2. match() → Mengambil Hasil Cocok

Metode match() digunakan untuk mengambil semua hasil yang cocok dengan pola tertentu. Jika regex memiliki flag g, hasilnya berupa array semua kecocokan. Tanpa g, hasilnya akan mengembalikan informasi detail termasuk capturing group.

Contoh tanpa flag g:

const text = "Hello JavaScript";
const result = text.match(/Java/);
console.log(result);Code language: JavaScript (javascript)

Outputnya:

  • hasil kecocokan
  • index ditemukan
  • input asli

Contoh dengan flag g:

const text = "apple, banana, apple, mango";
const result = text.match(/apple/g);
console.log(result); // ["apple", "apple"]Code language: JavaScript (javascript)

Metode ini sangat membantu saat mengambil data seperti:

  • list kata tertentu
  • semua angka dalam string
  • format tertentu (email, URL)

3. replace() → Mengganti Teks

Metode replace() digunakan untuk mengganti bagian string yang cocok dengan regex. Fungsi ini sangat sering dipakai dalam pengolahan teks.

Contoh mengganti satu kata:

const text = "Halo dunia!";
console.log(text.replace(/dunia/, "JavaScript"));Code language: JavaScript (javascript)

Contoh mengganti banyak kata (pakai flag g):

const text = "apple banana apple mango";
const result = text.replace(/apple/g, "orange");
console.log(result);Code language: JavaScript (javascript)

Contoh mengganti pola spesifik:

const text = "ID: 123-456";
console.log(text.replace(/\d/g, "*")); // "ID: ***-***"Code language: JavaScript (javascript)

replace() juga mendukung fungsi callback untuk penggantian yang lebih dinamis.

4. search() → Menemukan Index Pattern

Metode search() digunakan untuk menemukan index pertama dari pattern yang cocok dengan regex. Berbeda dengan match(), metode ini hanya mengembalikan:

  • posisi index hasil kecocokan pertama, atau
  • -1 jika tidak ditemukan

Contoh:

const text = "JavaScript sangat keren";
console.log(text.search(/keren/)); // 17Code language: JavaScript (javascript)

Metode ini sangat cocok jika kamu hanya ingin tahu posisi pertama tanpa butuh data detail lain.

5. split() → Memecah String Berdasarkan Pattern

Metode split() digunakan untuk memecah string menjadi array berdasarkan pola regex. Ini lebih fleksibel daripada split biasa yang hanya bisa menggunakan string.

Contoh memecah berdasarkan spasi:

const text = "belajar regex javascript lengkap";
const result = text.split(/\s+/);
console.log(result);Code language: JavaScript (javascript)

Contoh memecah berdasarkan koma dengan optional spasi:

const list = "apel, jeruk,  mangga, pisang";
const result = list.split(/,\s*/);
console.log(result);Code language: JavaScript (javascript)

Contoh mengambil angka dari teks:

const data = "ID-123-456-789";
const numbers = data.split(/\D+/);
console.log(numbers); // ["", "123", "456", "789"]Code language: JavaScript (javascript)

Pattern Matching Lanjutan

Setelah memahami dasar-dasar regex, kini saatnya masuk ke bagian yang lebih seru yaitu pattern matching lanjutan. Di sini kamu akan belajar berbagai teknik yang membuat Regular Expression JavaScript menjadi sangat fleksibel dan kuat. Mulai dari character class, quantifiers, anchors, hingga grouping dan alternation. Semua konsep ini akan memperluas kemampuanmu dalam membuat pola yang lebih kompleks.

Character Class [abc], [^abc]

Apa itu Character Class?

Character class adalah fitur regex yang memungkinkan kamu mencocokkan satu karakter dari beberapa kemungkinan karakter.

Contoh [abc]:

Pola ini berarti mencocokkan salah satu karakter: a, b, atau c.

const regex = /[abc]/;
console.log(regex.test("aris")); // true (ada huruf a)Code language: JavaScript (javascript)

[a-z]

Rentang karakter dari a sampai z.

const regex = /[a-z]/;Code language: JavaScript (javascript)

Negated Class [^abc]

^ di dalam bracket berarti bukan salah satu dari a, b, atau c.

const regex = /[^abc]/;
console.log(regex.test("ddd")); // true (karena bukan a b c)Code language: JavaScript (javascript)

Quantifiers *, +, ?, {n}, {n,m}

Quantifier digunakan untuk menentukan jumlah kemunculan dari sebuah karakter atau grup.

* → 0 atau lebih

const regex = /a*/;
console.log("aaa".match(regex)); // ["aaa"]Code language: JavaScript (javascript)

+ → 1 atau lebih

const regex = /a+/;
console.log("baaa".match(regex)); // ["aaa"]Code language: JavaScript (javascript)

? → 0 atau 1 (opsional)

const regex = /colou?r/;
console.log("color".match(regex)); // ["color"]
console.log("colour".match(regex)); // ["colour"]Code language: JavaScript (javascript)

{n} → tepat n kali

const regex = /\d{3}/;
console.log("Kode: 123".match(regex)); // ["123"]Code language: JavaScript (javascript)

{n,} → minimal n kali

const regex = /\d{2,}/;
console.log("12345".match(regex)); // ["12345"]Code language: JavaScript (javascript)

{n,m} → antara n hingga m kali

const regex = /\d{2,4}/;
console.log("12345".match(regex)); // ["1234"]Code language: JavaScript (javascript)

Anchors ^, $, \b, \B

Anchors digunakan untuk mencocokkan posisi dalam string, bukan karakter.

^ → awal string

const regex = /^Hello/;
console.log(regex.test("Hello world")); // trueCode language: JavaScript (javascript)

$ → akhir string

const regex = /world$/;
console.log(regex.test("Hello world")); // trueCode language: JavaScript (javascript)

\b → word boundary (batas kata)

Digunakan saat ingin mencocokkan pola pada batas kata.

const regex = /\bcat\b/;
console.log(regex.test("black cat white dog")); // trueCode language: JavaScript (javascript)

\B → kebalikan dari \b

const regex = /cat\B/;
console.log(regex.test("category")); // trueCode language: JavaScript (javascript)

Grouping () dan Backreference \1

Grouping digunakan untuk:

  • Mengelompokkan pola
  • Menangkap bagian tertentu (capturing group)
  • Membuat backreference (mengacu ke hasil sebelumnya)

Contoh grouping sederhana

const regex = /(ha)+/;
console.log("hahaha".match(regex)); // ["hahaha"]Code language: JavaScript (javascript)

Backreference \1

\1 mengacu pada hasil group pertama.

const regex = /(\w+)\s\1/;
console.log(regex.test("hello hello")); // trueCode language: JavaScript (javascript)

Cocok untuk mendeteksi teks duplikat.

Alternation |

Fitur ini mirip dengan operator OR, memungkinkan kamu mencocokkan beberapa pola.

Contoh:

const regex = /apple|banana|mango/;
console.log(regex.test("saya makan banana")); // trueCode language: JavaScript (javascript)

Contoh dengan grouping:

const regex = /gr(a|e)y/;
console.log(regex.test("gray")); // true
console.log(regex.test("grey")); // trueCode language: JavaScript (javascript)

Regex untuk Validasi Input

Regex menjadi sangat berguna dalam proses validasi input, terutama pada aplikasi web yang membutuhkan pengecekan cepat sebelum data dikirim ke server. Validasi input dengan regex di JavaScript memberikan fleksibilitas tinggi, efisiensi, dan dapat mencegah berbagai error maupun data tidak valid sejak dini.

Pada bagian ini, kita akan membahas cara membuat pola regex untuk memvalidasi email, nomor telepon, password, URL, hingga IP address, lengkap dengan contoh implementasinya dalam form validation JavaScript.

Validasi Email

Validasi email adalah salah satu penggunaan regex yang paling umum. Tujuan utama regex email adalah memastikan input memiliki struktur:

username @ domain . extension

Regex yang sering digunakan untuk email:

const emailRegex = /^[\w.-]+@[\w.-]+\.\w{2,}$/;Code language: JavaScript (javascript)

Contoh penggunaan:

const email = "user@example.com";
console.log(emailRegex.test(email)); // trueCode language: JavaScript (javascript)

Penjelasan pola:

  • ^[\w.-]+ → username (boleh huruf, angka, titik, dash)
  • @ → wajib ada
  • [\w.-]+ → domain
  • \.\w{2,}$ → extension minimal 2 karakter

Validasi Nomor Telepon

Format nomor telepon berbeda-beda, tetapi kita bisa membuat regex dasar yang fleksibel.

Contoh regex nomor telepon umum:

const phoneRegex = /^\+?\d{9,15}$/;Code language: JavaScript (javascript)

Maksud:

  • +? → opsional
  • \d{9,15} → panjang 9–15 digit

Contoh penggunaan:

console.log(phoneRegex.test("+628123456789")); // true
console.log(phoneRegex.test("08123456789")); // trueCode language: JavaScript (javascript)

Contoh format lebih kompleks (dengan spasi dan dash):

const phoneRegex2 = /^[+\d]?(?:[\d-.\s]{7,15})$/;Code language: JavaScript (javascript)

Validasi Password Kuat

Password yang kuat biasanya wajib memenuhi syarat berikut:

  • Minimal 8 karakter
  • Ada huruf besar
  • Ada huruf kecil
  • Ada angka
  • Ada simbol

Regex password kuat:

const strongPasswordRegex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[\W_]).{8,}$/;Code language: JavaScript (javascript)

Contoh:

console.log(strongPasswordRegex.test("ArisDev@2025")); // trueCode language: JavaScript (javascript)

Penjelasan:

  • (?=.*[a-z]) → ada huruf kecil
  • (?=.*[A-Z]) → ada huruf besar
  • (?=.*\d) → ada angka
  • (?=.*[\W_]) → ada simbol
  • .{8,} → minimal 8 karakter

Validasi URL dan IP Address

Validasi URL

Regex sederhana untuk URL:

const urlRegex = /^(https?:\/\/)?([\w-]+\.)+[\w-]{2,}(\/.*)?$/;Code language: JavaScript (javascript)

Contoh:

console.log(urlRegex.test("https://arisdev.com")); // trueCode language: JavaScript (javascript)

Penjelasan:

  • optional http:// atau https://
  • domain + extension
  • optional path

Validasi IPv4

Format IPv4: 0-255.0-255.0-255.0-255

Regex:

const ipRegex = /^(25[0-5]|2[0-4]\d|1\d{2}|[1-9]?\d)(\.(25[0-5]|2[0-4]\d|1\d{2}|[1-9]?\d)){3}$/;Code language: JavaScript (javascript)

Contoh:

console.log(ipRegex.test("192.168.1.1")); // trueCode language: JavaScript (javascript)

Penjelasan:

  • 25[0-5] → 0-255
  • 2[0-4]\d → 0-249
  • 1\d{2} → 0-199
  • [1-9]?\d → 0-99

Validasi IPv6

Format IPv6: 0-ffff:0-ffff:0-ffff:0-ffff:0-ffff:0-ffff:0-ffff:0-ffff

Regex:

const ipRegex = /^(?:[A-F0-9]{1,4}:){7}[A-F0-9]{1,4}$/i;Code language: JavaScript (javascript)

Contoh: console.log(ipRegex.test(“2001:0db8:85a3:0000:0000:8a2e:0370:7334”)); // true

Penjelasan:

  • ?:[A-F0-9]{1,4} → 0-ffff
  • {7} → 7 kali
  • [A-F0-9]{1,4} → 0-ffff
  • i → case-insensitive

Contoh Penggunaan Regex di Form Validation JavaScript

Berikut contoh simulasi form sederhana:

HTML (gambaran saja)

<input id="email" type="text">
<input id="password" type="password">
<button onclick="validate()">Submit</button>
<p id="message"></p>Code language: HTML, XML (xml)

JavaScript dengan regex:

function validate() {
    const email = document.getElementById("email").value;
    const password = document.getElementById("password").value;

    const emailRegex = /^[\w.-]+@[\w.-]+\.\w{2,}$/;
    const passwordRegex = /^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[\W_]).{8,}$/;

    if (!emailRegex.test(email)) {
        return showMessage("Email tidak valid!");
    }

    if (!passwordRegex.test(password)) {
        return showMessage("Password terlalu lemah!");
    }

    showMessage("Semua input valid!");
}

function showMessage(msg) {
    document.getElementById("message").innerText = msg;
}Code language: JavaScript (javascript)

Fitur di atas sangat sering ditemukan pada aplikasi web modern dan bisa dikembangkan menjadi validasi form yang lebih kompleks.

Regex Flags dan Opsi Tambahan

Regex di JavaScript tidak hanya tentang pola, karakter khusus, dan quantifier. Ada juga flags, yaitu opsi tambahan yang dapat mengubah perilaku pencarian pola. Flags ini sangat penting karena memengaruhi cara regex melakukan pencarian dalam string, menangani huruf besar-kecil, baris baru, karakter Unicode, dan lain-lain.

Dalam praktiknya, flags membantu membuat regex menjadi lebih fleksibel dan dapat digunakan pada berbagai kasus kompleks.

Global Flag: g

Flag g digunakan untuk mencari semua kecocokan (global match), bukan hanya kecocokan pertama.

Contoh tanpa g:

const text = "apple banana apple mango";
console.log(text.match(/apple/)); 
// output: ["apple"]Code language: JavaScript (javascript)

Hanya menemukan kecocokan pertama.

Contoh dengan g:

console.log(text.match(/apple/g));
// output: ["apple", "apple"]Code language: JavaScript (javascript)

Kapan menggunakan g?

  • Mencari semua angka di teks
  • Menghitung jumlah kemunculan kata
  • Parsing data dengan pola berulang

Case-Insensitive Flag: i

Flag i membuat pencarian tidak membedakan huruf besar dan kecil.

Contoh:

const regex = /hello/i;

console.log(regex.test("Hello")); // true
console.log(regex.test("HELLO")); // true
console.log(regex.test("hElLo")); // trueCode language: JavaScript (javascript)

Kapan digunakan?

  • Validasi email (huruf besar kecil tidak penting)
  • Mencari kata tertentu dalam paragraf
  • Mencocokkan username atau nama pengguna

Multiline Flag: m

Secara default, ^ dan $ hanya berfungsi di awal dan akhir seluruh string.

Dengan flag m, keduanya berlaku di setiap baris (multi-line mode).

Tanpa m:

const text = "Hello\nWorld";
console.log(text.match(/^World/)); 
// null (karena bukan awal string)Code language: JavaScript (javascript)

Dengan m:

console.log(text.match(/^World/m));
// ["World"]Code language: JavaScript (javascript)

Kapan dipakai?

  • Membaca file log
  • Memproses teks yang memiliki banyak baris
  • Mencocokkan pola pada setiap baris input

Sticky Flag: y

Flag y mencocokkan regex mulai dari posisi terakhir (lastIndex), bukan mencari ke seluruh string. Ini lebih ketat dibanding flag g.

Contoh:

const regex = /a/y;
const text = "aaba";

regex.lastIndex = 1;
console.log(regex.test(text)); // false (karena text[1] = a? Tidak—text[1] = a, tapi posisi ketat)Code language: JavaScript (javascript)

Flag y digunakan untuk parsing ketat, misalnya saat membaca token satu per satu.

Unicode Flag: u

Regex tanpa flag u kadang gagal saat mencocokkan karakter Unicode seperti emoji, huruf Mandarin, atau bahasa lain.

Misal:

console.log(/💖/.test("💖")); // false di beberapa kasus tanpa uCode language: JavaScript (javascript)

Dengan u:

console.log(/💖/u.test("💖")); // trueCode language: JavaScript (javascript)

Flag u sangat penting dalam aplikasi internasional.

Kombinasi Flags untuk Kasus Kompleks

Flags dapat dikombinasikan sesuai kebutuhan.

Contoh kombinasi umum:

gi — global + case-insensitive

const regex = /apple/gi;
const text = "Apple apple aPPle";

console.log(text.match(regex));
// ["Apple", "apple", "aPPle"]Code language: JavaScript (javascript)

gm — global + multiline

const text = `
    user1
    user2
    user3
    `;

console.log(text.match(/^user\d$/gm));
// ["user1", "user2", "user3"]Code language: JavaScript (javascript)

gim — lengkap

Global, case-insensitive, multiline.

const regex = /^hello/ gim;Code language: JavaScript (javascript)

Contoh kasus nyata, misalnya kamu ingin mencari seluruh kata “error” (tanpa peduli huruf besar kecil) pada setiap baris log:

const logRegex = /^error/ gim;Code language: JavaScript (javascript)

Regex tersebut akan:

  • Mencari di seluruh file .log (flag g)
  • Tidak peduli ERROR, Error, error (flag i)
  • Berlaku untuk setiap baris log (flag m)

Ringkasan Flags Regex

FlagDeskripsiKapan Dipakai
gglobal matchmencari semua kecocokan
icase-insensitivepencarian tanpa peduli kapital
mmultiline^ dan $ berlaku di setiap baris
ysticky matchparsing ketat berbasis posisi
uunicode supportemoji, huruf non-latin

Escape Character dan Special Character

Pada bagian ini kita akan membahas escape character dan special character yang menjadi fondasi penting dalam regular expression JavaScript. Banyak pemula yang kesulitan memahami bagian ini karena karakter-karakter tersebut memiliki fungsi khusus dan tidak bisa digunakan sembarangan. Dengan memahami daftar simbol penting ini, kamu akan semakin mahir membuat pattern regex yang kuat, fleksibel, dan tepat sasaran.

Escape Sequence Penting: \d, \w, \s, \D, \W, \S

Escape sequence digunakan untuk mewakili kelompok karakter tertentu tanpa menuliskannya satu per satu. Inilah yang membuat regex sangat efisien.

1. \d → digit (0–9)

Mencocokkan angka dari 0 hingga 9.

let regex = /\d+/;
console.log("Hai123".match(regex)); // ["123"]Code language: JavaScript (javascript)

2. \D → selain digit

Kebalikan dari \d.

let regex = /\D+/;
console.log("JS123".match(regex)); // ["JS"]Code language: JavaScript (javascript)

3. \w → word character (A–Z, a–z, 0–9, _)

Umumnya dipakai untuk validasi username, identifier, dan teks umum.

let regex = /\w+/;
console.log("user_01".match(regex)); // ["user_01"]Code language: JavaScript (javascript)

4. \W → selain word character

Kebalikan dari \w.

let regex = /\W+/;
console.log("Hello@2025".match(regex)); // ["@"]Code language: JavaScript (javascript)

5. \s → whitespace (spasi, tab, newline, dll.)

let regex = /\s/;
console.log("Hello World".match(regex)); // [" "]Code language: JavaScript (javascript)

6. \S → selain whitespace

let regex = /\S+/;
console.log("Hi There".match(regex)); // ["Hi"]Code language: JavaScript (javascript)

Escape sequence ini sangat sering digunakan dalam validasi input seperti email, password, nama, dan format teks lainnya.

Literal Escape: \\, \.

Beberapa karakter memiliki fungsi khusus dalam regex, sehingga jika kamu ingin menggunakannya sebagai karakter biasa (literal), kamu harus men-escape karakter tersebut.

1. \\ → mencocokkan backslash literal

Regex untuk mencari backslash harus ditulis \

let regex = /\\/;
console.log("\\folder".match(regex)); // ["\"]Code language: JavaScript (javascript)

2. \. → mencocokkan titik literal “.”

Karakter “.” dalam regex berarti “mencocokkan karakter apa saja”, jadi perlu di-escape jika ingin mencari titik sebenarnya.

let regex = /\./;
console.log("v1.2.3".match(regex)); // ["."]Code language: JavaScript (javascript)

Karakter Khusus Regex: . ^ $ * + ? ( ) [ ] { } |

Ini adalah karakter-karakter “sakral” dalam regex. Masing-masing memiliki fungsi unik:

KarakterFungsi
.mencocokkan semua karakter kecuali newline
^anchor: awal string
$anchor: akhir string
*quantifier: 0 atau lebih
+quantifier: 1 atau lebih
?quantifier opsional / lazy quantifier
()grouping & capturing
[]character class
{}quantifier jumlah
``OR / alternation

Contoh penggunaan beragam karakter khusus

1. Kleene star * dan plus +

console.log("aaa".match(/a*/)); // ["aaa"]
console.log("aaa".match(/a+/)); // ["aaa"]Code language: JavaScript (javascript)

2. Grouping ()

let regex = /(ha)+/;
console.log("hahaha".match(regex)); // ["hahaha"]Code language: JavaScript (javascript)

3. Alternation |

let regex = /kucing|anjing/;
console.log("Saya punya kucing".match(regex)); // ["kucing"]Code language: JavaScript (javascript)

4. Character class []

let regex = /[aeiou]/;
console.log("halo".match(regex)); // ["a"]Code language: JavaScript (javascript)

5. Anchors ^ dan $

let regex = /^Hello/;
console.log("Hello World".match(regex)); // ["Hello"]Code language: JavaScript (javascript)

Mengapa harus tahu karakter khusus?

Karena salah satu kesalahan terbesar pemula dalam regex adalah:

  • Menggunakan karakter khusus tanpa tahu fungsinya.
  • Mencari karakter literal tanpa di-escape.
  • Dengan memahami daftar ini, kamu bisa membuat regex jauh lebih akurat dan efisien.

Kesimpulan

Setelah mempelajari semua bagian dari tutorial lengkap ini, kamu kini telah memahami fondasi kuat tentang bagaimana regular expression JavaScript bekerja, bagaimana cara menulis pattern yang benar, hingga bagaimana melakukan pattern matching untuk kebutuhan validasi maupun manipulasi string.

Kita telah membahas cara membuat regex menggunakan literal dan constructor, memahami karakter dasar hingga meta character, menggunakan escape sequence, serta mengeksplorasi flags seperti g, i, dan m yang sangat penting untuk mengontrol perilaku pencarian. Kamu juga telah belajar berbagai metode bawaan JavaScript seperti test(), match(), replace(), search(), dan split() yang memungkinkan regex digunakan secara praktis dalam skenario nyata.

Tidak berhenti sampai di situ, kamu juga sudah mempelajari pattern matching lanjutan seperti character class, quantifier, anchors, grouping, backreference, hingga alternation |. Untuk penerapan nyata, kamu telah mempelajari cara membuat regex untuk validasi — seperti email, nomor telepon, password, URL, hingga IP address. Semua ini merupakan fondasi penting yang membuatmu siap membangun berbagai fitur berbasis teks yang lebih fleksibel dan canggih.

Dengan memahami seluruh materi dari artikel ini, kamu sudah memiliki dasar kuat untuk menggunakan regex dalam berbagai kebutuhan pengembangan web modern. Teruslah berlatih, eksplorasi pola-pola baru, dan kombinasikan regex dengan JavaScript untuk membangun aplikasi yang lebih cepat, aman, dan elegan.

1 JavaScript Dasar

2 JavaScript Menengah

Level Menengah fokus pada kemampuan yang lebih luas, seperti manipulasi DOM, event JavaScript, form validation, JSON, LocalStorage, SessionStorage, hingga asynchronous JavaScript dasar. Level ini membantu pengguna memahami bagaimana JavaScript bekerja untuk membuat website lebih interaktif dan dinamis, sangat relevan untuk tutorial dasar yang mengarahkan ke kemampuan membuat fitur web praktis.

3 JavaScript Lanjutan

4 JavaScript Mahir

5 JavaScript 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

slot mahjong

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

article 888000081

article 888000082

article 888000083

article 888000084

article 888000085

article 888000086

article 888000087

article 888000088

article 888000089

article 888000090

article 888000091

article 888000092

article 888000093

article 888000094

article 888000095

article 888000096

article 888000097

article 888000098

article 888000099

article 888000100

cuaca 898100116

cuaca 898100117

cuaca 898100118

cuaca 898100119

cuaca 898100120

cuaca 898100121

cuaca 898100122

cuaca 898100123

cuaca 898100124

cuaca 898100125

cuaca 898100126

cuaca 898100127

cuaca 898100128

cuaca 898100129

cuaca 898100130

cuaca 898100131

cuaca 898100132

cuaca 898100133

cuaca 898100134

cuaca 898100135

cuaca 898100136

cuaca 898100137

cuaca 898100138

cuaca 898100139

cuaca 898100140

cuaca 898100141

cuaca 898100142

cuaca 898100143

cuaca 898100144

cuaca 898100145

cuaca 898100146

cuaca 898100147

cuaca 898100148

cuaca 898100149

cuaca 898100150

cuaca 898100151

cuaca 898100152

cuaca 898100153

cuaca 898100154

cuaca 898100155

article 999990061

article 999990062

article 999990063

article 999990064

article 999990065

article 999990069

article 999990070

article 999990071

article 999990072

article 999990073

article 999990074

article 999990075

article 710000131

article 710000132

article 710000133

article 710000134

article 710000135

article 710000136

article 710000137

article 710000138

article 710000139

article 710000140

article 710000141

article 710000151

article 710000152

article 710000153

article 710000154

article 710000155

article 710000156

article 710000157

article 710000158

article 710000159

article 710000160

article 710000161

article 710000162

article 710000163

article 710000164

article 710000165

article 710000166

article 710000167

article 710000168

article 710000169

article 710000170

article 710000171

article 710000172

article 710000173

article 710000174

article 710000175

article 710000176

article 710000177

article 710000178

article 710000179

article 710000180

cuaca 638000091

cuaca 638000092

cuaca 638000093

cuaca 638000094

cuaca 638000095

cuaca 638000096

cuaca 638000097

cuaca 638000098

cuaca 638000099

cuaca 638000100

cuaca 638000101

cuaca 638000102

cuaca 638000103

cuaca 638000104

cuaca 638000105

budaya 538000031

budaya 538000032

budaya 538000033

budaya 538000034

budaya 538000035

budaya 538000036

budaya 538000037

budaya 538000038

budaya 538000039

budaya 538000040

budaya 538000046

budaya 538000047

budaya 538000048

budaya 538000049

budaya 538000050

budaya 538000051

budaya 538000052

budaya 538000053

budaya 538000054

budaya 538000055

budaya 538000056

budaya 538000057

budaya 538000058

budaya 538000059

budaya 538000060

psda 438000036

psda 438000037

psda 438000038

psda 438000039

psda 438000040

psda 438000041

psda 438000042

psda 438000043

psda 438000044

psda 438000045

psda 438000046

psda 438000047

psda 438000048

psda 438000049

psda 438000050

psda 438000051

psda 438000052

psda 438000053

psda 438000054

psda 438000055

psda 438000056

psda 438000057

psda 438000058

psda 438000059

psda 438000060

psda 438000061

psda 438000062

psda 438000063

psda 438000064

psda 438000065

psda 438000066

psda 438000067

psda 438000068

psda 438000069

psda 438000070

psda 438000071

psda 438000072

psda 438000073

psda 438000074

psda 438000075

psda 438000076

psda 438000077

psda 438000078

psda 438000079

psda 438000080

psda 438000081

psda 438000082

psda 438000083

psda 438000084

psda 438000085

psda 438000086

psda 438000087

psda 438000088

psda 438000089

psda 438000090

psda 438000091

psda 438000092

psda 438000093

psda 438000094

psda 438000095

psda 438000096

psda 438000097

psda 438000098

psda 438000099

psda 438000100

psda 438000101

psda 438000102

psda 438000103

psda 438000104

psda 438000105

psda 438000106

psda 438000107

psda 438000108

psda 438000109

psda 438000110

news-1701
news-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

slot mahjong

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

article 888000081

article 888000082

article 888000083

article 888000084

article 888000085

article 888000086

article 888000087

article 888000088

article 888000089

article 888000090

article 888000091

article 888000092

article 888000093

article 888000094

article 888000095

article 888000096

article 888000097

article 888000098

article 888000099

article 888000100

cuaca 898100116

cuaca 898100117

cuaca 898100118

cuaca 898100119

cuaca 898100120

cuaca 898100121

cuaca 898100122

cuaca 898100123

cuaca 898100124

cuaca 898100125

cuaca 898100126

cuaca 898100127

cuaca 898100128

cuaca 898100129

cuaca 898100130

cuaca 898100131

cuaca 898100132

cuaca 898100133

cuaca 898100134

cuaca 898100135

cuaca 898100136

cuaca 898100137

cuaca 898100138

cuaca 898100139

cuaca 898100140

cuaca 898100141

cuaca 898100142

cuaca 898100143

cuaca 898100144

cuaca 898100145

cuaca 898100146

cuaca 898100147

cuaca 898100148

cuaca 898100149

cuaca 898100150

cuaca 898100151

cuaca 898100152

cuaca 898100153

cuaca 898100154

cuaca 898100155

article 999990061

article 999990062

article 999990063

article 999990064

article 999990065

article 999990069

article 999990070

article 999990071

article 999990072

article 999990073

article 999990074

article 999990075

article 710000131

article 710000132

article 710000133

article 710000134

article 710000135

article 710000136

article 710000137

article 710000138

article 710000139

article 710000140

article 710000141

article 710000151

article 710000152

article 710000153

article 710000154

article 710000155

article 710000156

article 710000157

article 710000158

article 710000159

article 710000160

article 710000161

article 710000162

article 710000163

article 710000164

article 710000165

article 710000166

article 710000167

article 710000168

article 710000169

article 710000170

article 710000171

article 710000172

article 710000173

article 710000174

article 710000175

article 710000176

article 710000177

article 710000178

article 710000179

article 710000180

cuaca 638000091

cuaca 638000092

cuaca 638000093

cuaca 638000094

cuaca 638000095

cuaca 638000096

cuaca 638000097

cuaca 638000098

cuaca 638000099

cuaca 638000100

cuaca 638000101

cuaca 638000102

cuaca 638000103

cuaca 638000104

cuaca 638000105

budaya 538000031

budaya 538000032

budaya 538000033

budaya 538000034

budaya 538000035

budaya 538000036

budaya 538000037

budaya 538000038

budaya 538000039

budaya 538000040

budaya 538000046

budaya 538000047

budaya 538000048

budaya 538000049

budaya 538000050

budaya 538000051

budaya 538000052

budaya 538000053

budaya 538000054

budaya 538000055

budaya 538000056

budaya 538000057

budaya 538000058

budaya 538000059

budaya 538000060

psda 438000036

psda 438000037

psda 438000038

psda 438000039

psda 438000040

psda 438000041

psda 438000042

psda 438000043

psda 438000044

psda 438000045

psda 438000046

psda 438000047

psda 438000048

psda 438000049

psda 438000050

psda 438000051

psda 438000052

psda 438000053

psda 438000054

psda 438000055

psda 438000056

psda 438000057

psda 438000058

psda 438000059

psda 438000060

psda 438000061

psda 438000062

psda 438000063

psda 438000064

psda 438000065

psda 438000066

psda 438000067

psda 438000068

psda 438000069

psda 438000070

psda 438000071

psda 438000072

psda 438000073

psda 438000074

psda 438000075

psda 438000076

psda 438000077

psda 438000078

psda 438000079

psda 438000080

psda 438000081

psda 438000082

psda 438000083

psda 438000084

psda 438000085

psda 438000086

psda 438000087

psda 438000088

psda 438000089

psda 438000090

psda 438000091

psda 438000092

psda 438000093

psda 438000094

psda 438000095

psda 438000096

psda 438000097

psda 438000098

psda 438000099

psda 438000100

psda 438000101

psda 438000102

psda 438000103

psda 438000104

psda 438000105

psda 438000106

psda 438000107

psda 438000108

psda 438000109

psda 438000110

news-1701
news-1701

sabung ayam online

yakinjp

yakinjp

rtp yakinjp

slot thailand

yakinjp

yakinjp

yakin jp

yakinjp id

maujp

maujp

maujp

maujp

slot mahjong

SGP Pools

slot mahjong

sabung ayam online

slot mahjong

SLOT THAILAND

article 710000011

article 710000012

article 710000013

article 710000014

article 710000015

article 710000016

article 710000017

article 710000018

article 710000019

article 710000020

article 710000021

article 710000022

article 710000023

article 710000024

article 710000025

article 710000026

article 710000027

article 710000028

article 710000029

article 710000030

article 710000031

article 710000032

article 710000033

article 710000034

article 710000035

article 710000036

article 710000037

article 710000038

article 710000039

article 710000040

article 710000041

article 710000042

article 710000043

article 710000044

article 710000045

article 710000046

article 710000047

article 710000048

article 710000049

article 710000050

article 710000051

article 710000052

article 710000053

article 710000054

article 710000055

article 710000056

article 710000057

article 710000058

article 710000059

article 710000060

kasus 898100001

kasus 898100002

kasus 898100003

kasus 898100004

kasus 898100005

kasus 898100006

kasus 898100007

kasus 898100008

kasus 898100009

kasus 898100010

kasus 898100011

kasus 898100012

kasus 898100013

kasus 898100014

kasus 898100015

kasus 898100016

kasus 898100017

kasus 898100018

kasus 898100019

kasus 898100020

kasus 898100021

kasus 898100022

kasus 898100023

kasus 898100024

kasus 898100025

kasus 898100026

kasus 898100027

kasus 898100028

kasus 898100029

kasus 898100030

kasus 898100031

kasus 898100032

kasus 898100033

kasus 898100034

kasus 898100035

kasus 898100036

kasus 898100037

kasus 898100038

kasus 898100039

kasus 898100040

cuaca 898100001

cuaca 898100002

cuaca 898100003

cuaca 898100004

cuaca 898100005

cuaca 898100006

cuaca 898100007

cuaca 898100008

cuaca 898100009

cuaca 898100010

cuaca 898100011

cuaca 898100012

cuaca 898100013

cuaca 898100014

cuaca 898100015

cuaca 898100016

cuaca 898100017

cuaca 898100018

cuaca 898100019

cuaca 898100020

cuaca 898100021

cuaca 898100022

cuaca 898100023

cuaca 898100024

cuaca 898100025

cuaca 898100026

cuaca 898100027

cuaca 898100028

cuaca 898100029

cuaca 898100030

cuaca 898100031

cuaca 898100032

cuaca 898100033

cuaca 898100034

cuaca 898100035

cuaca 898100036

cuaca 898100037

cuaca 898100038

cuaca 898100039

cuaca 898100040

article 868000011

article 868000012

article 868000013

article 868000014

article 868000015

article 868000016

article 868000017

article 868000018

article 868000019

article 868000020

article 868100021

article 868100022

article 868100023

article 868100024

article 868100025

article 868100026

article 868100027

article 868100028

article 868100029

article 868100030

article 868100031

article 868100032

article 868100033

article 868100034

article 868100035

article 868100036

article 868100037

article 868100038

article 868100039

article 868100040

article 868100041

article 868100042

article 868100043

article 868100044

article 868100045

article 868100046

article 868100047

article 868100048

article 868100049

article 868100050

article 868100051

article 868100052

article 868100053

article 868100054

article 868100055

article 868100056

article 868100057

article 868100058

article 868100059

article 868100060

article 878000011

article 878000012

article 878000013

article 878000014

article 878000015

article 878000016

article 878000017

article 878000018

article 878000019

article 878000020

article 878800021

article 878800022

article 878800023

article 878800024

article 878800025

article 878800026

article 878800027

article 878800028

article 878800029

article 878800030

article 878800031

article 878800032

article 878800033

article 878800034

article 878800035

article 878800036

article 878800037

article 878800038

article 878800039

article 878800040

article 888000031

article 888000032

article 888000033

article 888000034

article 888000035

article 888000036

article 888000037

article 888000038

article 888000039

article 888000040

article 888000041

article 888000042

article 888000043

article 888000044

article 888000045

article 888000046

article 888000047

article 888000048

article 888000049

article 888000050

article 888000051

article 888000052

article 888000053

article 888000054

article 888000055

article 888000056

article 888000057

article 888000058

article 888000059

article 888000060

article 888000061

article 888000062

article 888000063

article 888000064

article 888000065

article 888000066

article 888000067

article 888000068

article 888000069

article 888000070

article 328000601

article 328000602

article 328000603

article 328000604

article 328000605

article 328000606

article 328000607

article 328000608

article 328000609

article 328000610

article 328000611

article 328000612

article 328000613

article 328000614

article 328000615

article 328000616

article 328000617

article 328000618

article 328000619

article 328000620

article 328000621

article 328000622

article 328000623

article 328000624

article 328000625

article 328000626

article 328000627

article 328000628

article 328000629

article 328000630

article 328000631

article 328000632

article 328000633

article 328000634

article 328000635

article 328000636

article 328000637

article 328000638

article 328000639

article 328000640

article 328000641

article 328000642

article 328000643

article 328000644

article 328000645

article 328000646

article 328000647

article 328000648

article 328000649

article 328000650

article 999990001

article 999990002

article 999990003

article 999990004

article 999990005

article 999990006

article 999990007

article 999990008

article 999990009

article 999990010

article 999990011

article 999990012

article 999990013

article 999990014

article 999990015

article 999990016

article 999990017

article 999990018

article 999990019

article 999990020

news-1701