Update: This version of XRegExp is outdated. See XRegExp.com for the latest, greatest version.
If you haven't seen the prior versions, XRegExp is an MIT-licensed JavaScript library that provides an augmented, cross-browser implementation of regular expressions, including support for additional modifiers and syntax. Several convenience methods and a new, powerful recursive-construct parser that uses regex delimiters are also included.
Here's what you get beyond the standard JavaScript regex features:
- Added regex syntax:
- Comprehensive named capture support. (Improved)
- Comment patterns:
(?#…)
. (New)
- Added regex modifiers (flags):
s
(singleline), to make dot match all characters including newlines.x
(extended), for free-spacing and comments.
- Added awesome:
- Reduced cross-browser inconsistencies. (More)
- Recursive-construct parser with regex delimiters. (New)
- An easy way to cache and reuse regex objects. (New)
- The ability to safely embed literal text in your regex patterns. (New)
- A method to add modifiers to existing regex objects.
- Regex
call
andapply
methods, which make generically working with functions and regexes easier. (New)
All of this can be yours for the low, low price of 2.4 KB. Version 0.5 also introduces extensive documentation and code examples.
If you're using a previous version, note that there are a few non-backward compatible changes for the sake of strict ECMA-262 Edition 3 compliance and compatibility with upcoming ECMAScript 4 changes.
- The
XRegExp.overrideNative
function has been removed, since it is no longer possible to override native constructors in Firefox 3 or ECMAScript 4 (as proposed). - Named capture syntax has been changed from
(<name>…)
to(?<name>…)
, which is the standard in most regex libraries and under consideration for ES4. Named capture is now always available, and does not require thek
modifier. - Due to cross-browser compatibility issues, previous versions enforced that a leading, unescaped
]
within a character class was treated as a literal character, which is how things work in most regex flavors. XRegExp now follows ECMA-262 Edition 3 on this point.[]
is an empty set and never matches (this is enforced in all browsers).
Get it while it's hot! Check out the new XRegExp documentation and source code.
First post! Seriously, amazing work Steve.
XRegExp ftw!
Second post! Schwing, and great work again!
Thanks, guys! Incidentally, JResig also seems to approve. 🙂
Excellent work. The cache method is actually something I had already implemented myself, and it is quite useful.
Great work, really usefull!
XRegExp got another great mention over on Andrew Dupont’s blog. Thanks, all!