UNPKG

util-ex

Version:

Browser-friendly enhanced util fully compatible with standard node.js

25 lines (22 loc) 1.02 kB
/** * Escapes a string for use in a regular expression pattern. * * @param {string} string - The string to be escaped. Must be of type 'string', otherwise a `TypeError` will be thrown. * @returns {string} - The escaped string where special characters are escaped to ensure they are not interpreted as special syntax within a regular expression. * * @example * const input = "Hello, world! (It's me.)"; * const escaped = escapeStringRegexp(input); * console.log(escaped); // Outputs: "Hello, world! \(It's me\.\)" */ export function escapeStringRegexp(string) { if (typeof string !== 'string') { throw new TypeError('Expected a string'); } // Escape characters with special meaning either inside or outside character sets. // Use a simple backslash escape when it’s always valid, and a `\xnn` escape when the simpler form would be disallowed by Unicode patterns’ stricter grammar. return string .replace(/[|\\{}()[\]^$+*?.]/g, '\\$&') .replace(/-/g, '\\x2d'); } export default escapeStringRegexp;