75 points
*
19 points
Deleted by creator
permalink
report
parent
reply
16 points

by not ever using == and !=, but only === and !==

permalink
report
parent
reply
10 points

Because in reality you’re not doing stupid stuff like that in the image. And using Typescript definitely helps.

However I’m always annoyed that the month parameter when constructing a date object is 0 based. So 1st of Jan is

new Date(2024, 0, 1)
permalink
report
parent
reply
8 points
*
Deleted by creator
permalink
report
parent
reply
1 point

Looks confusing at first, but I found it nice for accessing a month array.

const months = ["Jan", "Feb", ...];

months[0] === "Jan";

const label = months[date.getMonth()];
permalink
report
parent
reply
10 points

Typescript :)

permalink
report
parent
reply
3 points

Yep. It’s the only reason I’m still somewhat sane.

permalink
report
parent
reply
7 points

By banishing the bad part of the language with linter.

For instance, standard eslint preset has rules that enforce usage of ===, https://eslint.org/docs/latest/rules/eqeqeq

These rules often come with project starter template

permalink
report
parent
reply
4 points

And typescript is basically just a linter on steroids

permalink
report
parent
reply
7 points

almost forced to for web front end. why you would use it anywhere else, however, i will never know

permalink
report
parent
reply
4 points

The same reason people drive their car to buy groceries.

You bought it for something where it was the only option, driving 30km to work everyday. But ever since you got it, the trip to the super market is kinda too hot in the summer and too cold in the winter and what if you spontaneously need to buy more than expected?

People learn it for front end dev, and then they use what they know for back end too.

permalink
report
parent
reply
2 points
*

Ikr? English is hard /s

permalink
report
parent
reply
47 points
*

I still don’t understand the === operator

Edit: I think a more type strict ==? Pretty sure I understand the point of typescript now.

permalink
report
reply
129 points
*

So in JavaScript there’s the assignment

=

and the comparator is

==

Since there’s no types JS will do implicit conversion before comparison when using == in a case like this

if(false == '0'){
    //this is true
}

But with === it doesn’t. It means literally compare these

if(false === '0'){
    //this is false
}else{
    //so this will execute instead 
}

But this, however, will

var someState = false;
 if(someState === false){
    //this is true
}
permalink
report
parent
reply
72 points
Deleted by creator
permalink
report
parent
reply
23 points

Np. closed as duplicate

permalink
report
parent
reply
68 points
> 1 == 1
true
> 1 == '1'
true
> 1 === '1'
false

(from node REPL)

Basically it’s the real equals sign

permalink
report
parent
reply
46 points

The short answer is that your language needs === when it fucked up the semantics of ==, but it’s also too popular and you can’t fix it without breaking half the web.

permalink
report
parent
reply
2 points

Or when it is something like Prolog, where equality is inherently a messy and complex concept.

permalink
report
parent
reply
28 points

It’s like the ==, but there’s one more =

permalink
report
parent
reply
21 points

JS’s == has some gotchas and you almost never want to use it. So === is what == should have been.

All examples are true:

"1" == true
[1, 2] == "1,2" 
" " == false
null == undefined 

It isn’t that insane. But some invariants that you may expect don’t hold.

"" == 0
"0" == 0
"" != "0" 
permalink
report
parent
reply
5 points

One neat feature is you can compare to both null and undefined at the same time, without other falsey values giving false positives. Although that’s not necessary as often now that we have nullish coalescing and optional chaining.

permalink
report
parent
reply
2 points

I just tested and Terser will convert v === null || v === undefined to null==v. Personally I would prefer to read the code that explicitly shows that it is checking for both and let my minifier/optimizer worry about generating compact code.

permalink
report
parent
reply
18 points
*

It’s also important if you’re checking hashes (at least, it was - if you’re using correct hashing algorithm that isn’t ancient, you will not have this problem).

Because if you take for example “0e462097431906509019562988736854” (which is md5(“240610708”), but also applicable to most other hashing algorithms that hash to a hex string), if(“0e462097431906509019562988736854” == 0) is true. So any other data that hashes to any variantion of “0e[1-9]+” will pass the check, for example:

md5("240610708") == md5("hashcatqlffzszeRcrt")

that equals to

"0e462097431906509019562988736854" == "0e242700999142460696437005736231"

which thanks to scientific notation and no strict type checking can also mean

0462097431906509019562988736854 == 0242700999142460696437005736231

which is

0 == 0 `

I did use md5 as an example because the strings are pretty short, but it’s applicable to a whole lot of other hashes. And the problem is that if you use one of the strings that hash to a magic hash in a vulnerable site, it will pass the password check for any user who’s password also hashes to a magic hash. There’s not really a high chance of that happening, but there’s still a lot of hashes that do hash to it.

permalink
report
parent
reply
10 points

that is terrifying

permalink
report
parent
reply
1 point

If you’re checking passwords, you should be using constant time string checking, anyway.

More likely, you should let your bcrypt library do it for you.

permalink
report
parent
reply
18 points

== but for JavaScript. What you don’t understand is the == of JavaScript.

permalink
report
parent
reply
6 points

The other comments explains it in pretty good detail, but when I was learning my teacher explained it sort of like a mnemonic.

1 + 1 = 2 is read “one plus one equals two”

1 + 1 == 2 is read “one plus one is equal to two”

1 + 1 === 2 is read “one plus one is really equal to two”

And you hit the nail on the head, is that === is type explicit while == is implicit.

permalink
report
parent
reply
3 points
*

I’d use something like:

= becomes

== equals

=== is identical to

It’s funny how everyone thinks “equals” in this context should be “identical to” when, in normal language, it doesn’t really mean that at all!

permalink
report
parent
reply
4 points
*

Like == but more strict. The == operator will do type conversion, so 0 == '' will actually be true, as an example. Sometimes (honestly, most times) you may want to compare more strictly.

See this StackOverflow answer: https://stackoverflow.com/questions/359494/which-equals-operator-vs-should-be-used-in-javascript-comparisons

permalink
report
parent
reply
4 points
*

You don’t need Typescript, you need an linter (eslint).

=== is your basic equality like most languages. == will implicitly cast type.

The breakdown is here: https://262.ecma-international.org/5.1/#sec-11.9.3

Modern JS says to never use == unless you’re comparing against null or undefined.

permalink
report
parent
reply
1 point
Deleted by creator
permalink
report
parent
reply
13 points

JS devs should have a font that turns == into ≈.

permalink
report
reply
12 points

I wish the assignment operator wasn’t the equal sign.

permalink
report
reply
19 points
x 👈 5
permalink
report
parent
reply
13 points

Ok deal, but that means we need to change the equality operator to 👉👈

permalink
report
parent
reply
5 points

You sonnofabitch I’m in!:-P

permalink
report
parent
reply
8 points
x 🔫 5

the pew pew principle /s

permalink
report
parent
reply
8 points

Interpreter: Wait, x is 5?

This code: Always has been.

permalink
report
parent
reply
10 points

:=

permalink
report
parent
reply
3 points

That’s delayed assignment.

permalink
report
parent
reply
6 points

procrastination assignment

permalink
report
parent
reply
1 point

In Haskell, it’s the same as the mathematical = symbol.

permalink
report
parent
reply
12 points
*

ChatGpt: 1+1≈2

permalink
report
reply
2 points

Reddit: 1+1=your muther (sic, x2)

X: 1+1≈we should violently overthrow the government

4chan: nvm, I don’t want to get banned for saying this one

permalink
report
parent
reply
2 points

4chan: “Gamer words”

permalink
report
parent
reply
3 points

No, that’s Discord 🙃

permalink
report
parent
reply

Programmer Humor

!programmer_humor@programming.dev

Create post

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

  • Keep content in english
  • No advertisements
  • Posts must be related to programming or programmer topics

Community stats

  • 3.1K

    Monthly active users

  • 1K

    Posts

  • 38K

    Comments