JavaScript isNaN() Coerces Values When Testing For Numbers

Posted August 8, 2012 at 9:31 AM by Ben Nadel

Tags: Javascript / DHTML

Recently, I was tripped up in my JavaScript debugging due to the way that the isNaN() (ie. is "not a number") function treats its argument. I was trying to track down an elusive bug that would occasionally present a numeric ID as the empty string (""). To figure out why this was happening, I put an isNaN() check in place in order to perform logging. Except, the error kept happening and no logging was being performed.

After debugging my debugging code (ironic!), I discovered that calling isNaN() on the empty string actually returned "false"; that is, isNaN() considers the empty string to be a valid number. After reading up on the isNaN() documentation, I found out that isNaN() tries to coerce its argument into a number before returning a result.

Now, with coercion in mind, things started to make more sense:

  • Empty strings can be coerced into a falsey value.
  • Falsey values can be coerced into Zero.
  • Zero is a valid number.
  • Hence, isNaN() sees empty string as a number.

To see this in action, I put together a small demo that runs the empty string and some truthy / falsey values through isNaN(). I also played around with using parseFloat() as a means to bypass numeric coercion:

  • <!doctype html>
  • <html>
  • <head>
  • <meta charset="utf-8" />
  • <title>Testing JavaScript isNaN() Value Coercion</title>
  • <script type="text/javascript">
  •  
  •  
  • // Empty strings can be coerced to falsey values. And all
  • // truthy / falsey values can be coerced to numbers. As such,
  • // truthy / falsey values are *not* not numbers.
  •  
  • console.log( "Empty String isNaN: ", isNaN( "" ) );
  •  
  • console.log( "False isNaN: ", isNaN( false ) );
  •  
  • console.log( "True isNaN: ", isNaN( true ) );
  •  
  •  
  • // -------------------------------------------------- //
  • // -------------------------------------------------- //
  • console.log( ". . . . ." );
  • // -------------------------------------------------- //
  • // -------------------------------------------------- //
  •  
  •  
  • // ParseFloat() coerces arguments to a String value and then
  • // tries to extract the numeric value. As such, it doesn't
  • // fall victim to truthy / falsey coercion.
  •  
  • console.log( "Empty String isNaN: ", isNaN( parseFloat( "" ) ) );
  •  
  • console.log( "False isNaN: ", isNaN( parseFloat( false ) ) );
  •  
  • console.log( "True isNaN: ", isNaN( parseFloat( true ) ) );
  •  
  •  
  • // -------------------------------------------------- //
  • // -------------------------------------------------- //
  • console.log( ". . . . ." );
  • // -------------------------------------------------- //
  • // -------------------------------------------------- //
  •  
  •  
  • // Simply exploring how parseFloat() coerces values (forcing
  • // them to be Strings before it parses them).
  •  
  • var complexObject = {};
  •  
  • // Override the core to-string value.
  • complexObject.toString = function(){
  •  
  • // Return a NUMBER string.
  • return( "012345" );
  •  
  • };
  •  
  • // Test float parsing.
  • console.log(
  • "Complex Object Float: ",
  • parseFloat( complexObject )
  • );
  •  
  •  
  • </script>
  • </head>
  • <body>
  • <!-- Left inentionally blank. -->
  • </body>
  • </html>

When we run the above code, we get the following console log output:

Empty String isNaN: false
False isNaN: false
True isNaN: false
. . . . .
Empty String isNaN: true
False isNaN: true
True isNaN: true
. . . . .
Complex Object Float: 12345

As you can see, all truthy / falsey values are seen as "numbers" by the isNaN() function. Furthermore, trying to use parseFloat() as an intermediary cuts out the numeric type coercion because parseFloat() coerces its values into Strings before parsing them.

I guess this is the documented behavior of isNaN(); but, seeing as I've used the isNaN() function maybe 3 times in my career, I wasn't fully aware of how it worked. But now I know - and knowing is half the battle!



Reader Comments

There are no comments posted for this web log entry.

Post A Comment

Comment Etiquette: Please do not post spam. Please keep the comments on-topic. Please do not post unrelated questions or large chunks of code. And, above all, please be nice to each other - we're trying to have a good conversation here.

Please review the following issues:

Author Name:


Author Email:

Author Website:

Comment:

Supported HTML tags for formatting: <strong>bold</strong>   <em>italic</em>   <code>code</code>







  • Help Wanted - Find Your Next ColdFusion Job
Ben Nadel's Company - Epicenter Consulting Recent Blog Comments
May 17, 2013 at 7:42 PM
HashKeyCopier - An AngularJS Utility Class For Merging Cached And Live Data
Ben - thanks so much for posting these Angular articles and findings, they've been a huge help towards learning one of the more 'complex' JavaScript frameworks out there (IMO). I have been using Angu ... read »
May 16, 2013 at 5:01 PM
UPDATE: Parsing CSV Data Files In ColdFusion With csvToArray()
Your code was the closest thing I've found to obtaining some direction for converting ISO fields to values that CF can translate properly. Thank you for posting! ... read »
May 15, 2013 at 10:37 PM
Very Simple Pusher And ColdFusion Powered Chat
hi id making plz easy ... read »
May 15, 2013 at 6:07 PM
Making SOAP Web Service Requests With ColdFusion And CFHTTP
Ben, you once again saved my bacon at work. Thank you, thank you, thank you! ... read »
May 15, 2013 at 4:15 PM
What If All User Interface (UI) Data Came In Reports?
@Josh, Thanks! @Ben, I definitely recommend the David West book "Object Thinking" I've been quoting from. It goes deeply into the philosophy and history of OO programming. His breadth ... read »
May 15, 2013 at 11:36 AM
Ask Ben: Print Part Of A Web Page With jQuery
I found this helpfull when you need to keep (refresh) the original parent page after closing the iframe child print dialog (Hoping you're not using a form at this time so it won't submit again): On ... read »
May 14, 2013 at 7:13 PM
What If All User Interface (UI) Data Came In Reports?
@Jonah, If there's any books you'd recommend on the subject of domain modelling, I'd love to hear it. I just downloaded the free PDF of "Domain Driven Design Quickly". Figured I'd give it ... read »
May 14, 2013 at 6:57 PM
The UX Of Prototyping: Low-Fidelity Is The New High-Fidelity
@Phillip, I'm not sure I follow what you mean? Are you saying that you looked at the list of widgets provided by the jQuery UI and let that be your style guide? ... read »
InVision App - Prototyping Made Beautiful With Prototyping Tools