JavaScript Regex: String Does Not Contain

By  on  

For some reason I think that regular expressions can solve every problem and for some reason I always find out the regular expression I'm trying to create is too complicated and probably not the best route to getting what I want.  Case in point:  I needed to create a regular expression which is meant to not match a string.  I don't want to match a string which includes [requires-login] but do want to match everything else.  Let's set aside the why for now, here's how I accomplished what I wanted:

// Adding extra forward slashes for "[" and "]"
var regex = '^(?!.*?\\[requires-login\\])';

// Compile
var re = new RegExp(regex);

So why do I want to do this?  Within my intern client side tests, I mark tests requiring login as [requires-login], and if a username and password aren't passed in via command line, I want to skip those tests.  In that case, I leverage intern's grep function to match tests without the given string.  I'd prefer to mark a few tests with [requires-login] instead of mark most of them as [no-login].

Sometimes you want to do things within the web development world which aren't ideal but you simply need to accomplish them within a given parameter set.  This is one of those cases.  In the end you need to make it happen, and in this case, I did so!

Recent Features

  • By
    9 Mind-Blowing Canvas Demos

    The <canvas> element has been a revelation for the visual experts among our ranks.  Canvas provides the means for incredible and efficient animations with the added bonus of no Flash; these developers can flash their awesome JavaScript skills instead.  Here are nine unbelievable canvas demos that...

  • By
    LightFace:  Facebook Lightbox for MooTools

    One of the web components I've always loved has been Facebook's modal dialog.  This "lightbox" isn't like others:  no dark overlay, no obnoxious animating to size, and it doesn't try to do "too much."  With Facebook's dialog in mind, I've created LightFace:  a Facebook lightbox...

Incredible Demos

  • By
    Spatial Navigation

    Spatial navigation is the ability to navigate to focusable elements based on their position in a given space.  Spatial navigation is a must when your site or app must respond to arrow keys, a perfect example being a television with directional pad remote.  Firefox OS TV apps are simply...

  • By
    Instagram For MooTools

    If you're still rocking an iPhone and fancy taking a photo every now and then, you'd be crazy not to be using an app called Instagram.  With Instagram you take the photos just as you would with your native iPhone camera app, but Instagram...

Discussion

  1. I’m wondering why you couldn’t simply write a simpler expression to match

    [required-login]

    and then negate the match. e.g.

    
    
  2. ArugulaExpression

    Your example may be for an “un-ideal scenario”, but I can imagine many common situations that require matching one portion and then un-matching another portion.

    Thank you for this and all of your other short lessons.

    – fan

  3. MaxArt

    Just keep in mind that regular expressions are ususally quite slow, so for you case it may be better another approach. In this case, the classic use of indexOf may be better… and clearer, too. In fact, another con point is that regexes are way harder to understand and especially *maintain*.

    • I have to bend to Intern’s API, and that means using grep, which requires a regex. Otherwise I’d agree with you.

    • You “have to bend to”… sounds like a fail right there. What is so great about this Intern that makes it mandatory in your workflow? (Disclaimer: I know nothing about it.)

    • You could very easily argue that Intern allowing you to write a regex is the ultimate in configurability.

  4. I’ve used Regex Coach in the past but abandoned it for RegexBuddy. It’s not a free tool, but I think it is among the best on the market.

  5. Thanks David. As a side question, how do you mark the tests in intern?

  6. What does the comment about “extra forward slashes” mean? I can’t see any forward slashes.

    • Chirag

      I think he meant “backward slashes”

  7. Hi David,

    I completely agree that regular expressions can solve lots of problem especially when we write complex and sophisticated search programs and validation code. It makes life alot easier by reducing several lines of code into just one. But to apply it, you must learn it and learning it requires some effort, atleast basics should be clear.

  8. Gabriel

    Thanks David! This is just what I needed. Indeed I run into an awkward situation too and the only solution was to find out that regex.

Wrap your code in <pre class="{language}"></pre> tags, link to a GitHub gist, JSFiddle fiddle, or CodePen pen to embed!