Radek Simko
Radek Simko

Reputation: 16126

JavaScript regex with escaped slashes does not replace

Do i have to escape slashes when putting them into regular expression?

myString = '/courses/test/user';
myString.replace(/\/courses\/([^\/]*)\/.*/, "$1");
document.write(myString);

Instead of printing "test", it prints the whole source string.

See this demo:

http://jsbin.com/esaro3/2/edit

Upvotes: 43

Views: 92887

Answers (5)

Maxim Mazurok
Maxim Mazurok

Reputation: 4138

Note, that you don't have to escape / if you use new RegExp() constructor:

console.log(new RegExp("a/b").test("a/b"))

Upvotes: 3

Brett Zamir
Brett Zamir

Reputation: 14345

Actually, you don't need to escape the slash when inside a character class as in one part of your example (i.e., [^\/]* is fine as just [^/]*). If it is outside of a character class (like with the rest of your example such as \/courses), then you do need to escape slashes.

Upvotes: 14

rajesh_kw
rajesh_kw

Reputation: 1592

/[\/]/g matches forward slashes.
/[\\]/g matches backward slashes.

Upvotes: 21

Anon.
Anon.

Reputation: 59983

string.replace doesn't modify the original string. Instead, a returns a new string that has had the replacement performed.

Try:

myString = '/courses/test/user';
document.write(myString.replace(/\/courses\/([^\/]*)\/.*/, "$1"));

Upvotes: 9

Reid
Reid

Reputation: 19409

Your regex is perfect, and yes, you must escape slashes since JavaScript uses the slashes to indicate regexes.

However, the problem is that JavaScript's replace method does not perform an in-place replace. That is, it does not actually change the string -- it just gives you the result of the replace.

Try this:

myString = '/courses/test/user';
myString = myString.replace(/\/courses\/([^\/]*)\/.*/, "$1");
document.write(myString);

This sets myString to the replaced value.

Upvotes: 52

Related Questions