• raspberriesareyummy@lemmy.world
    link
    fedilink
    arrow-up
    42
    arrow-down
    8
    ·
    9 months ago

    BS. A language shouldn’t have operators that allow non sensical operations like string concatenation when one operand is not a string.

    • squaresinger@lemmy.world
      link
      fedilink
      arrow-up
      8
      arrow-down
      1
      ·
      9 months ago

      Especially that + and - act differently. If + does string concattenation, - should also do some string action or throw an error in this situation.

      • FooBarrington@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        9 months ago

        That’s the case in many languages, pretty much in all that don’t have a separate string concatenation operator.

        • squaresinger@lemmy.world
          link
          fedilink
          arrow-up
          1
          ·
          9 months ago

          Yeah, and almost all languages I know then would throw an exception when you try to use - with a string, and if they offer multiple operators that take a string and a number, they always only perform string operations with that and never cast to a number type to do math operations with it.

          (e.g. some languages have + for string concatenation and * to add the same string X time together, so e.g. "ab" * 2 => "abab". It’s a terrible idea to have + perform a string operation and - performs a math operation.)

            • squaresinger@lemmy.world
              link
              fedilink
              arrow-up
              0
              arrow-down
              1
              ·
              9 months ago

              Because there’s in fact no operator overloading happening, true, but that’s mostly an under-the-hood topic.

              It should not happen no matter why it does happen under the hood.

              Operator overloading for string - string is wrong and type coercion to implicitly cast this to int(string) - int(string) is just as wrong.

              • FooBarrington@lemmy.world
                link
                fedilink
                arrow-up
                1
                ·
                9 months ago

                There is operator overloading happening - the + operator has a different meaning depending on the types involved. Your issue however seems to be with the type coercion, not the operator overloading.

                It should not happen no matter why it does happen under the hood.

                If you don’t want it to happen either use a different language, or ensure you don’t run into this case (e.g. by using Typescript). It’s an unfortunate fact that this does happen, and it will never be removed due to backwards compatibility.

                • squaresinger@lemmy.world
                  link
                  fedilink
                  arrow-up
                  2
                  arrow-down
                  1
                  ·
                  9 months ago

                  There is operator overloading happening - the + operator has a different meaning depending on the types involved. Your issue however seems to be with the type coercion, not the operator overloading.

                  For string + string and number + number there is operator overloading, that’s correct. For string + number there is not, there’s only type coercion. It becomes string + string(number). All of that is fine. Other languages do that as well.

                  What’s not fine is that JS also looks the other way on the type coercion tree: There’s no string - string overloading, so it goes down the type coercion tree, looking for any - operation that it can cast to and it ends up with number(string) - number(string), which makes no sense at all.

                  If you don’t want it to happen either use a different language, or ensure you don’t run into this case (e.g. by using Typescript). It’s an unfortunate fact that this does happen, and it will never be removed due to backwards compatibility.

                  It’s not the point of the discussion that there are other languages that are better. This here is about complaining about bad language design, and no matter how you turn this, this is not a matter of taste or anything, this is just bad language design.

                  You are obviously right that this crap will stay in JS forever. That doesn’t make it good design.

    • 3abas@lemm.ee
      link
      fedilink
      arrow-up
      11
      arrow-down
      5
      ·
      9 months ago

      It’s not nonsensical, implicit type coercion is a feature of JavaScript, it’s perfectly logical and predictable.

      JavaScript is a filthy beast, it’s not the right tool for every job, but it’s not nonsensical.

      When you follow a string with a +, it concatenates it with the next value (converted to string if needed). This makes sense, and it’s a very standard convention in most languages.

      Applying arithmetic to a string would be nonsensical, which they don’t do.

        • 3abas@lemm.ee
          link
          fedilink
          arrow-up
          3
          arrow-down
          1
          ·
          9 months ago

          Sure. And you’re entitled to yours. But words have meaning and this isn’t MY OPINION, it’s objective reality. It follows strict rules for predictable output, it is not nonsensical.

          You’re entitled to think it’s nonsense, and you’d be wrong. You don’t have to like implicit type coercion, but it’s popular and in many languages for good reason…

          Language Implicit Coercion Example
          JavaScript '5' - 1 → 4
          PHP '5' + 1 → 6
          Perl '5' + 1 → 6
          Bash $(( '5' + 1 )) → 6
          Lua "5" + 1 → 6
          R "5" + 1 → 6
          MATLAB '5' + 1 → 54 (ASCII math)
          SQL (MySQL) '5' + 1 → 6
          Visual Basic '5' + 1 → 6
          TypeScript '5' - 1 → 4
          Tcl "5" + 1 → 6
          Awk '5' + 1 → 6
          PowerShell '5' + 1 → 6
          ColdFusion '5' + 1 → 6
          VBScript '5' + 1 → 6
          ActionScript '5' - 1 → 4
          Objective-J '5' - 1 → 4
          Excel Formula "5" + 1 → 6
          PostScript (5) 1 add6

          I think JavaScript is filthy, I’m at home with C#, but I understand and don’t fear ITC.

          • raspberriesareyummy@lemmy.world
            link
            fedilink
            arrow-up
            4
            arrow-down
            2
            ·
            9 months ago

            Also, you contradicted yourself just then and there. Not a single of your examples does string concatenation for these types. It’s only JS

            • bss03@infosec.pub
              link
              fedilink
              English
              arrow-up
              3
              ·
              9 months ago
              • In https://lemm.ee/comment/20947041 they claimed “implicit type coercion” and showed many examples; they did NOT claim “string concatenation”.
              • However, that was in reply to https://lemmy.world/comment/17473361 which was talking about “implicit conversion to string” which is a specific type of “implicit type coercion”; NONE of the examples given involved a conversion to string.
              • But also, that was in reply to https://lemm.ee/comment/20939144 which only mentions “implicit type coercion” in general.

              So, I think probably everyone in the thread is “correct”, but you are actually talking past one another.

              I think the JS behavior is a bad design choice, but it is well documented and consistent across implementations.

              • raspberriesareyummy@lemmy.world
                link
                fedilink
                arrow-up
                1
                arrow-down
                2
                ·
                9 months ago

                Read the thread again, it seems you slipped somewhere. This was all about the claim that implicit conversion to string somehow could make sense.