this post was submitted on 28 Jun 2025
1080 points (99.2% liked)

Programmer Humor

24603 readers
945 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 
you are viewing a single comment's thread
view the rest of the comments
[–] marcos@lemmy.world 13 points 2 days ago (1 children)

The Javascript literal interpretation of NaN never fails to amuse me.

[–] squaresinger@lemmy.world 4 points 1 day ago (1 children)
"a"+"b" -> "ab"
"a"-"b" -> NaN
[–] marcos@lemmy.world 2 points 1 day ago (1 children)

Yeah:

parseInt("a") -> NoT a NuMbEr
[–] squaresinger@lemmy.world 2 points 1 day ago

Sure, but the main issue here is that JS doesn't only auto cast to more generic but in both directions.

Maybe a better example is this:

"a" + 1 -> "a1"
"a" - 1 -> NaN

With + it casts to the more generic string type and then executes the overloaded + as a string concatenation.

But with - it doesn't throw an exception (e.g. something like "Method not implemented"), but instead casts to the more specific number type, and "a" becomes a NaN, and NaN - 1 becomes NaN as well.

There's no situation where "a" - "b" makes any sense or could be regarded as intentional, so it should just throw an error. String minus number also only makes sense in very specific cases (specifically, the string being a number), so also here I'd expect an error.

If the programmer really wants to subtract one number from another and one or both of them are of type string, then the programmer should convert to number manually, e.g. using parseInt("1") - parseInt("2").