• kevincox
    link
    fedilink
    arrow-up
    21
    arrow-down
    1
    ·
    11 months ago

    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" 
    
    • Feathercrown@lemmy.world
      link
      fedilink
      English
      arrow-up
      5
      ·
      11 months ago

      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.

      • kevincox
        link
        fedilink
        arrow-up
        1
        ·
        11 months ago

        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.

        • SzethFriendOfNimi@lemmy.world
          link
          fedilink
          arrow-up
          1
          arrow-down
          1
          ·
          11 months ago

          Try changing to const === variable. That’s most likely what’s it doing to minimize the risk of accidental assignment.

          • kevincox
            link
            fedilink
            arrow-up
            2
            ·
            11 months ago

            Wut? This is an automated optimizer. It is not worried about accidental assignment.