5

I came across a strange behaviour when doing some regular expressions in JavaScript today (Firefox 3 on Windows Vista).

var str = "format_%A";
var format = /(?:^|\s)format_(.*?)(?:\s|$)/.exec(str);

console.log(format);    // ["format_%A", "%A"]
console.log(format[0]); // "format_undefined"
console.log(format[1]); // Undefined

There's nothing wrong with the regular expression. As you can see, it has matched the correct part in the first console.log call.

Internet Explorer 7 and Chrome both behave as expected: format[1] returns "%A" (well, Internet Explorer 7 doing something right was a bit unexpected...)

Is this a bug in Firefox, or some "feature" I don't know about?

5
  • I've never seen the literal matching syntax you're using here. Can you point at some web resource where one can read about it? Commented Jan 11, 2009 at 12:34
  • I think at least a link to the previous almost-the-same question should be provided: stackoverflow.com/questions/432493/… Commented Jan 11, 2009 at 12:57
  • @PEZ: what literal matching syntax are you talking about? Commented Jan 11, 2009 at 14:12
  • 1
    @PEZ: developer.mozilla.org/en-US/docs/JavaScript/Guide/… Commented Oct 31, 2012 at 21:19
  • This is not a firefox issue, it's a firebug issue. Commented Jun 19, 2014 at 15:27

2 Answers 2

16

This is because console.log() works like printf(). The first argument to console.log() is actually a format string which may be followed with additional arguments. %A is a placeholder. For example:

console.log("My name is %A", "John"); // My name is "John"

See console.log() documentation for details. %A and any other undocumented placeholders seem to do the same as %o.

Sign up to request clarification or add additional context in comments.

2 Comments

To be clear, this is not how console.log behaves in Safari's Web Inspector.
Firefox does not behave like this - this is apparently a firebug specific feature. Has this ever been anything other than a firebug feature?
1

Seems like %A somehow translates into the string undefined.

Try escaping the %A part, I think that will solve the problem.

2 Comments

Good catch. It's treated as a URL escape (like %20 and the like) but then %A isn't one of those so gets to be undefined.
Seems to be an issue with Firebug

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.