I will post some questions in JavaScript from today onwards share your own solutions without running these code on your console.
null === undefined
null == undefined
2+"4"
2-"3"
""+2
+"2"
I will post some questions in JavaScript from today onwards share your own solutions without running these code on your console.
null === undefined
null == undefined
2+"4"
2-"3"
""+2
+"2"
For further actions, you may consider blocking this person and/or reporting abuse
codemee -
Atsushi Suzuki -
Carrie -
Rez Moss -
Top comments (40)
One of my favorite web-slinger questions (for fun, not for job interviews) is: can you name all 8 of the falsy things?
Here's the first falsy thing, to get you started, which is pretty much a gimme:
I'm out. What are the last 2?
Shoutout! I didn't get
NaN
-NaN and -0
Here they all are. I realize that two of them will bring out the angry mob with their torches and pitchforks. But my disclaimer is that I did not write the language.
First the easy 6 falsy things:
Plus the final two falsy things, the second of which being an HTML-ism (part of the HTML specification):
I can't think of any case where those would be falsy. What exactly did you experiment with that made it appear that way?
Sanity check...
Logs
truthy
twiceUnless I'm missing some trickery in the original comment,
[]
and{}
are truthy values in JavaScript.Without looking:
I love these! I even have a codepen that's kind of like this
Oh, yeah, I know my weird Javascript math 🎉
1 and 2 I know because of work since null and undefined can be a pain when testing.
3 is string concatination with 2 being made a string to make it magically work.
4 is making the string a number to make the math operator magically work.
5 is similar to 3 in that it's concatinating an (empty) string with a number that magically becomes a string.
6 is fun because
+
is the shorthand for type converting to an int.You have to wrap it in parens b/c JS treats toplevel curlies as a "block" rather than an object. But, of course, if you begin a line with parens, then it will become a function call on the previous line, if one exists, so for sanity's sake, begin any paren line with a semicolon (same for brackets).
Personally, I think it's really iffy to say that
{}
and[]
are falsy values. I've always understood "falsy" to mean you can drop it into a conditional and it will behave likefalse
would have:Got 3. and 5. wrong, haha.
I supposed that the first operand would decide which implementation of + would be used, but I guess the rule is: string wins :D
Both convert the number to string and do a string concatination, even in one the number is the first operand and in the other the string is the first operand.
Ah, yes.
I was talking about 3 and 5 :D
Oh i thought it was 5 and 6.
yeah 3 and 5 are Strings😁
Oddly,
node -e "if ([] == false) console.log('truthy')"
logstruthy
, butnode -e "if ({} == false) console.log('truthy')"
doesn't.Oh Javascript...
The moral of the story: always use
===
.6 uses + as a short form for type conversion
I scored 4 out of 6. But if I wasn't able to run them as I went, it would be much lower.
Also, I feel like you should add
"2"+4
right after2+"4"
, b/c I was definitely wondering if the casting decision was based on which one was first. Eg in Ruby,+
is a method call, so2+"4"
would be callingInteger#+
and"2"+4
would be callingString#+
, thus the ordering implies different behaviour, even though+
in math is commutative. I know that's not how JS works, but it means that I would at least be entertaining the possibility of non-commutativity.Uhhh I love these!
I've got one for you!
Without running this in the console let me know how much is
0.1 + 0.2
Hint: it's a number bigger than the one you are thinking of right now.
0.30000000000000004
but this would happen on any IEEE floating point machine