Split a String by Special Characters in JavaScript

avatar

Borislav Hadzhiev

Thu Nov 18 20212 min read

Split a String by Special Characters #

To split a string by special characters, call the split() method on the string, passing it a regular expression that matches any of the special characters as a parameter. The method will split the string on each occurrence of a special character and return an array containing the results.

index.js
const str = 'a.b-c=d/e_f'; const result = str.split(/[.\-=/_]/); // ๐Ÿ‘‡๏ธ ['a', 'b', 'c', 'd' ,'e' ,'f'] console.log(result);
If you're looking for a regular expression that matches all special characters, scroll down to the last example.

The only parameter we passed to the split method is a regular expression - a separator on which we want to split the string.

The forward slashes / / mark the beginning and end of the regular expression.

The square brackets [] are called a character class and match any of the characters between the brackets. You could adjust the characters to your needs.

The regular expression in the example matches a dot, hyphen, equal sign, forward slash and underscore.

Some characters, e.g. hyphens, or backslashes have to be escaped, because they have a special meaning.
index.js
const str = 'z=a-b\\c'; const result = str.split(/[=\-\\]/); // ๐Ÿ‘‡๏ธ ['z', 'a', 'b', 'c'] console.log(result);

If you need to also split on a space, you can add a space between the square brackets.

index.js
const str = 'a.b c'; const result = str.split(/[. ]/); // ๐Ÿ‘‡๏ธ ['a', 'b', 'c'] console.log(result);

If you ever need help reading a regular expression, check this regex cheatsheet from MDN out.

Here's an example of a regular expression that splits the string on all special characters.

index.js
const str = 'a.b,c-d_e=f\\g/h'; const specialChars = /[`!@#$%^&*()_+\-=\[\]{};':"\\|,.<>\/?~]/; const result = str.split(specialChars); // ๐Ÿ‘‡๏ธ ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h'] console.log(result);

The regular expression we used matches any special character. You could also add a space in the square brackets, if you consider a space to be a special character.

Conversely, you could also remove any of the characters between the brackets, if you don't consider them to be special characters.

Join my newsletter

I'll send you 1 email a week with links to all of the articles I've written that week

Buy Me A Coffee