• dan@upvote.au
    link
    fedilink
    arrow-up
    3
    ·
    edit-2
    22 days ago

    Use TypeScript, and nonsensical things like adding arrays to objects will be compile-time errors.

    • CanadaPlus@lemmy.sdf.org
      link
      fedilink
      arrow-up
      0
      ·
      edit-2
      22 days ago

      Yup. The libraries underneath will still allow nonsense at runtime, though, and it will now be harder to see, so it’s a partial solution as done in standard practice.

      An all-TypeScript stack, if you could pull it off, would be the way to go.

        • thevoidzero@lemmy.world
          link
          fedilink
          arrow-up
          0
          ·
          22 days ago

          If there was an easy way to use rust or something on webassemly and use that instead of JS. I’d be so happy, but I can’t find how to do it without npm.

  • Victor@lemmy.world
    link
    fedilink
    arrow-up
    1
    ·
    edit-2
    22 days ago

    In node, I get the same result in both cases. "[object Object]"

    It’s calling the toString() method on both of them, which in the array case is the same as calling .join(",") on the array. For an empty array, that results in an empty string added to "[object Object]" at either end in the respective case in the picture.

    Not sure how we’d get 0 though. Anybody know an implementation that does that? Browsers do that maybe? Which way is spec compliant? Number([]) is 0, and I think maybe it’s in the spec that the algorithm for type coercion includes an initial attempt to convert to Number before falling back to toString()? I dunno, this is all off the top of my head.

    • PoolloverNathan@programming.dev
      link
      fedilink
      arrow-up
      1
      ·
      edit-2
      22 days ago

      The inspector REPL evaluates as a statement-with-value (like eval), so the {} at the beginning is considered an empty block, not an object. This leaves +[], which is 0. I don’t know what would make Node differ, however.

      Edit: Tested it myself. It seems Node prefers evaluating this as an expression when it can, but explicitly using eval gives the inspector behavior:

      • Victor@lemmy.world
        link
        fedilink
        arrow-up
        1
        ·
        22 days ago

        So there’s yet another level of quirkery to this bullshit then, it seems. 😆 Nice digging! 🤝

        I also noticed that if you surround the curlies with parentheses, you get the same again:

        > eval('{} + []')
        0
        > eval('({}) + []')
        '[object Object]'
        
  • orangeboats@lemmy.world
    link
    fedilink
    arrow-up
    1
    ·
    21 days ago

    This is why I try my damnedest not to write in weakly typed languages.

    string + object makes no logical sense, but the language will be like “'no biggie, you probably meant string + string so let’s convert the object to string”! And so all hell breaks loose when the language’s assumption is wrong.

  • Mesa@programming.dev
    link
    fedilink
    arrow-up
    1
    ·
    edit-2
    19 days ago

    I’m in this no-experience-to-apprenticeship program and everyone in my class thinks type coercion is the greatest thing ever.