Movatterモバイル変換


[0]ホーム

URL:


Menu
×
See More 
Sign In
+1 Get Certified Upgrade For Teachers Spaces Get Certified Upgrade For Teachers Spaces
   ❮     
     ❯   

Basic JavaScript

JS TutorialJS SyntaxJS VariablesJS OperatorsJS If ConditionsJS LoopsJS StringsJS NumbersJS FunctionsJS ObjectsJS DatesJS ArraysJS Typed ArraysJS SetsJS MapsJS MathJS RegExpJS Data TypesJS ErrorsJS EventsJS ProgrammingJS ReferencesJS Versions

JS Advanced

JS FunctionsJS ObjectsJS ClassesJS IterationsJS AsynchronousJS ModulesJS Meta & ProxyJS HTML DOMJS WindowsJS Web APIJS AJAXJS JSONJS jQueryJS GraphicsJS ExamplesJS 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

FlagDescription
/dPerforms substring matches (new 2022)
/gPerforms a global match (find all)
/iPerforms case-insensitive matching
/mPerforms multiline matching
/sAllows . (dot) to match line terminators (new 2018)
/uEnables Unicode support (new 2015)
/vAn upgrade to the /u flag for better Unicode support (new 2025)
/yPerforms 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 othercharacter.

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 regexmetacharacter /\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

PropertyDescription
globalReturnstrue if the /g flag is set
hasIndicesReturnstrue if the /d flag is set
ignoreCaseReturnstrue if the /i flag is set
multilineReturnstrue if the /m flag is set
dotAllReturnstrue if the /s flag is set
stickyReturnstrue if the /y flag is set
unicodeReturnstrue if the /u flag is set
unicodeSetsReturnstrue if the /v flag is set

The dotAll Property

ThedotAll property returnstrueif the /s flag is set.

Example

const pattern = /W3Schools/s;

let result = pattern.dotAll;
Try it Yourself »

The global Property

Theglobal property returnstrueif the /g flag is set.

Example

const pattern = /W3Schools/g;

let result = pattern.global;
Try it Yourself »

The hasIndices Property

ThehasIndices property returnstrueif the /d flag is set.

Example

const pattern = /W3Schools/d;

let result = pattern.hasIndices;
Try it Yourself »

The ignoreCase Property

TheignoreCase property returnstrueif the /i flag is set.

Example

const pattern = /W3Schools/i;

let result = pattern.ignoreCase;
Try it Yourself »

The multiline Property

Themultiline property returnstrueif the /m flag is set.

Example

const pattern = /W3Schools/m;

let result = pattern.multiline;
Try it Yourself »

The sticky Property

Thesticky property returnstrueif the /y flag is set.

Example

const pattern = /W3Schools/y;

let result = pattern.sticky;
Try it Yourself »

The unicode Property

Theunicode property returnstrueif the /u flag is set.

Example

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

let result = pattern.unicode;
Try it Yourself »

The unicodeSets Property

TheunicodeSets property returnstrueif 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 ExpressionSearch andReplace 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:
sales@w3schools.com

Report Error

If you want to report an error, or if you want to make a suggestion, send us an e-mail:
help@w3schools.com

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 ourterms of use,cookies andprivacy policy.

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


[8]ページ先頭

©2009-2025 Movatter.jp