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
    CSS 3D Folding Animation

    Google Plus provides loads of inspiration for front-end developers, especially when it comes to the CSS and JavaScript wonders they create. Last year I duplicated their incredible PhotoStack effect with both MooTools and pure CSS; this time I'm going to duplicate...

  • By
    An Interview with Eric Meyer

    Your early CSS books were instrumental in pushing my love for front end technologies. What was it about CSS that you fell in love with and drove you to write about it? At first blush, it was the simplicity of it as compared to the table-and-spacer...

Incredible Demos

  • By
    Page Visibility API

    One event that's always been lacking within the document is a signal for when the user is looking at a given tab, or another tab. When does the user switch off our site to look at something else? When do they come back?

  • By
    Six Degrees of Kevin Bacon Using MooTools 1.2

    As you can probably tell, I try to mix some fun in with my MooTools madness but I also try to make my examples as practical as possible. Well...this may not be one of those times. I love movies and useless movie trivia so naturally I'm...

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!