Menu
×
   ❮     
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS DSA TYPESCRIPT ANGULAR ANGULARJS GIT POSTGRESQL MONGODB ASP AI R GO KOTLIN SWIFT SASS VUE GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE INTRO TO PROGRAMMING INTRO TO HTML & CSS BASH RUST

Basic JavaScript

JS Tutorial JS Introduction JS Where To JS Output

JS Syntax

JS Syntax JS Statements JS Comments JS Variables JS Variables JS Let JS Const JS Types

JS Operators

JS Operators JS Arithmetic JS Assignment JS Comparisons JS Conditional JS If JS If Else JS Ternary JS Switch JS Booleans JS Logical

JS Loops

JS Loops JS Loop for JS Loop while JS Break JS Continue JS Control Flow

JS Strings

JS Strings JS String Templates JS String Methods JS String Search JS String Reference

JS Numbers

JS Numbers JS Numbers JS Number Methods JS Number Properties JS Number Reference JS Bitwise JS BigInt

JS Functions

Function Path Function Intro Function Invocation Function Parameters Function Returns Function Arguments Function Expressions Function Arrow Function Quiz

JS Objects

Object Path Object Intro Object Properties Object Methods Object this Object Display Object Constructors

JS Scope

JS Scope JS Code Blocks JS Hoisting JS Strict Mode

JS Dates

JS Dates JS Date Formats JS Date Get JS Date Set JS Date Methods

JS Arrays

JS Arrays JS Array Methods JS Array Search JS Array Sort JS Array Iterations JS Array Reference JS Array Const

JS Sets

JS Sets JS Set Methods JS Set Logic JS Set WeakSet JS Set Reference

JS Maps

JS Maps JS Map Methods JS Map WeakMap JS Map Reference

JS Iterations

JS Loops JS Iterables JS Iterators JS Generators

JS Math

JS Math JS Math Reference JS Math Random

JS RexExp

JS RegExp Flags JS RegExp Classes JS RegExp Metachars JS RegExp Assertions JS RegExp Quantifiers JS RegExp Patterns JS RegExp Objects JS RegExp Methods

JS Data Types

JS Destructuring JS Data Types JS Primitive Data JS Object Types JS typeof JS toString() JS Type Conversion

JS Errors

JS Errors Intro JS Errors Silent JS Error Statements JS Error Object

JS Debugging

JS Debugging Debugging Debug Console Debug Breakpoints Debug Errors Debug Async

JS Conventions

JS Style Guide JS Best Practices JS Mistakes JS Performance

JS References

JS Keywords Reference JS Keywords Reserved JS Operator Reference JS Operator Precedence

JS Versions

JS 2026 JS 2025 JS 2024 JS 2023 JS 2022 JS 2021 JS 2020 JS 2019 JS 2018 JS 2017 JS 2016 JS Versions JS 2015 (ES6) JS 2009 (ES5) JS 1999 (ES3) JS IE / Edge JS History

JS HTML

JS HTML DOM JS Events JS Projects New

JS Advanced

JS Temporal  New JS Functions JS Objects JS Classes JS Asynchronous JS Modules JS Meta & Proxy JS Typed Arrays JS DOM Navigation JS Windows JS Web APIs JS AJAX JS JSON JS jQuery JS Graphics JS Examples JS Reference


JavaScript RegExp Flags

RegExp Modifier Flags

Flags are parameters that can modify how a regex pattern is used, such as making it case-insensitive or global.

/pattern/flags

JavaScript Regex Flags

Revised July 2025

Flag Description
/d Performs substring matches (new 2022)
/g Performs a global match (find all)
/i Performs case-insensitive matching
/m Performs multiline matching
/s Allows . (dot) to match line terminators (new 2018)
/u Enables Unicode support (new 2015)
/v An upgrade to the /u flag for better Unicode support (new 2025)
/y Performs a "sticky" search (new 2015)

Flag Syntax: /pattern/flags

/Opening delimiter for the regular expression
patternRegular expression (a search criteria)
/Closing delimiter for the regular expression
flagsOne or more single modifier flags

RegExp /g Flag (Global)

The /g flag matches all occurrences of the pattern, rather than just the first one.

Example

A global search for "is" in a string:

let text = "Is this all there is?";
const pattern = /is/g;

let result = text.match(pattern);

Try it Yourself »


RegExp /i Flag (Insensitive)

The /i flag makes the match case-insensitive: /abc/i matches "abc", "AbC", "ABC".

Example

A case-insensitive search for "w3schools" in a string:

let text = "Visit W3Schools";
const pattern = /is/g;

let result = text.match(pattern);

Try it Yourself »


RegExp /d Flag

The /d flag specifies the start and the end of a match.

Example

Match every sub text that starts or ends with aa or bb:

let text = "aaaabb";
const pattern = /(aa)(bb)/d;

let result = text.match(pattern);
Try it Yourself »

RegExp /s Flag (Single line/DotAll)

The /s flag allows the . (dot) metacharacter to match newline characters (\n) in addition to any other character.

Example

Without the /s flag, \n does not match . (wildchars):

let text = "Line\nLine.";
const pattern = /Line./gs;

let result = text.match(pattern);
Try it Yourself »

RegExp /y Flag (Sticky):

The /y flag performs a "sticky" search from the lastIndex property of the RegExp object.

The /y flag lets a match start at the exact position where the last match ended.

Examples

let text = "abc def ghi";
const pattern = /\w+/y;

// Start match from position 4
pattern.lastIndex = 4;
let result = text.match(pattern);
Try it Yourself »

The /y flag must be set to allow match from a position.

This will not work:

let text = "abc def ghi";
const pattern = /\w+/;

// Start match from position 4
pattern.lastIndex = 4;
let result = text.match(pattern);
Try it Yourself »

Note

The example above uses a regex metacharacter /\w+/.

The meaning of /\w+/ is "mach any word".

You will learn more about metacharacters in the next chapters.



RegExp /u Flag (Unicode)

The /u flag enables full Unicode support in a regular expression.

By default, JavaScript RegExp treats 4-byte Unicode characters (like emojis or less common symbols) as two separate 2-byte "surrogate" code units.

The /u flag treats the pattern as a sequence of Unicode code points, which is important for correctly handling of characters outside the Basic Multilingual Plane (BMP).

Example

let text = "䷀";
const pattern = /\u{04DC0}/u;

// Returns true:
let result = pattern.test(text);
Try it Yourself »

Without the /u flag, regular expressions are not "Unicode-aware".

Example

let text = "䷀";
const pattern = /\u{04DC0}/;

// Returns false:
let result = pattern.test(text);
Try it Yourself »

Note

JavaScript 2025 introduced the /v flag as an "upgrade" to the /u flag.

The /v Flag enables more Unicode-related features.


RegExp /v Flag (Unicode Sets)

The /v flag is an upgrade to the /u flag for better Unicode support.

It enables more Unicode-related features.

The new features are:

  • The \p escape sequence matches strings, instead of just characters.
  • The character class is upgraded to allow intersection, union, and subtraction syntaxes, as well as matching multiple Unicode characters.

Example

let text = "Hello 😄";
const pattern = /\p{Emoji}/v;

// Returns true:
let result = pattern.test(text);
Try it Yourself »

Without the /v flag, regular expressions are not "Unicode-aware".

Example

let text = "Hello 😄";
const pattern = /\p{Emoji}/;

// Returns false:
let result = pattern.test(text);
Try it Yourself »

RegExp Group Modifiers (?flag)

The (?flag) syntax is a group modifier (inline flag modifier).

It allows for modifying flags in a part of a pattern, rather than to the entire pattern.

(?flags:pattern) enables the flags only for the pattern in the group.

Example

The i flag is only enabled for the W3Schools part of the pattern.

let text = "W3Schools tutorials.";
const pattern = /(?i:WShools) tutorials/;

// Returns true:
let result = pattern.test(text);
Try it Yourself »

The i flag is only enabled for the W3Schools part of the pattern.

let text = "W3Schools Tutorials.";
const pattern = /(?i:W3Sshools) tutorials/;

// Returns false:
let result = pattern.test(text);
Try it Yourself »

JavaScript Regex Flag Properties

Revised July 2025

Property Description
global Returns true if the /g flag is set
hasIndices Returns true if the /d flag is set
ignoreCase Returns true if the /i flag is set
multiline Returns true if the /m flag is set
dotAll Returns true if the /s flag is set
sticky Returns true if the /y flag is set
unicode Returns true if the /u flag is set
unicodeSets Returns true if the /v flag is set

The dotAll Property

The dotAll property returns true if the /s flag is set.

Example

const pattern = /W3Schools/s;

let result = pattern.dotAll;
Try it Yourself »

The global Property

The global property returns true if the /g flag is set.

Example

const pattern = /W3Schools/g;

let result = pattern.global;
Try it Yourself »

The hasIndices Property

The hasIndices property returns true if the /d flag is set.

Example

const pattern = /W3Schools/d;

let result = pattern.hasIndices;
Try it Yourself »

The ignoreCase Property

The ignoreCase property returns true if the /i flag is set.

Example

const pattern = /W3Schools/i;

let result = pattern.ignoreCase;
Try it Yourself »

The multiline Property

The multiline property returns true if the /m flag is set.

Example

const pattern = /W3Schools/m;

let result = pattern.multiline;
Try it Yourself »

The sticky Property

The sticky property returns true if the /y flag is set.

Example

const pattern = /W3Schools/y;

let result = pattern.sticky;
Try it Yourself »

The unicode Property

The unicode property returns true if the /u flag is set.

Example

let text = "䷀";
const pattern = /\u{04DC0}/u;

let result = pattern.unicode;
Try it Yourself »

The unicodeSets Property

The unicodeSets property returns true if the /v flag is set.

Example

let text = "Hello 😄";
const pattern = /\p{Emoji}/v;

let result = pattern.unicodeSets;
Try it Yourself »

Regular Expression Methods

Regular Expression Search and Replace can be done with different methods.

These are the most common:

String Methods

MethodDescription
match(regex) Returns an Array of results
matchAll(regex) Returns an Iterator of results
replace(regex) Returns a new String
replaceAll(regex) Returns a new String
search(regex) Returns the index of the first match
split(regex) Returns an Array of results

RegExp Methods

MethodDescription
regex.exec() Returns an Iterator of results
regex.test() Returns true or false


×

Contact Sales

If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail:
[email protected]

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
[email protected]

W3Schools is optimized for learning and training. Examples might be simplified to improve reading and learning. Tutorials, references, and examples are constantly reviewed to avoid errors, but we cannot warrant full correctness of all content. While using W3Schools, you agree to have read and accepted our terms of use, cookies and privacy policy.

Copyright 1999-2026 by Refsnes Data. All Rights Reserved. W3Schools is Powered by W3.CSS.

-->