aburtang@lemmy.world to Programmer Humor@lemmy.ml · 12 days agoEvil Oneslemmy.worldimagemessage-square76fedilinkarrow-up1991arrow-down131
arrow-up1960arrow-down1imageEvil Oneslemmy.worldaburtang@lemmy.world to Programmer Humor@lemmy.ml · 12 days agomessage-square76fedilink
minus-squaremasterspace@lemmy.calinkfedilinkEnglisharrow-up3arrow-down2·edit-212 days agoI think that might be user error as I can’t recreate that:
minus-squarepooberbee (they/she)@lemmy.mllinkfedilinkarrow-up1arrow-down1·12 days agoYeah, you would get a runtime error calling that member without checking that it exists.
minus-squaremasterspace@lemmy.calinkfedilinkEnglisharrow-up1·edit-27 days agoBecause that object is of a type where that member may or may not exist. That is literally the exact same behaviour as Java or C#. If I cast or type check it to make sure it’s of type Bar rather than checking for the member explicitly it still works: And when I cast it to Foo it throws a compile time error, not a runtime error: I think your issues may just like in the semantics of how Type checking works in JavaScript / Typescript.
I think that might be user error as I can’t recreate that:
Yeah, you would get a runtime error calling that member without checking that it exists.
Because that object is of a type where that member may or may not exist. That is literally the exact same behaviour as Java or C#.
If I cast or type check it to make sure it’s of type Bar rather than checking for the member explicitly it still works:
And when I cast it to Foo it throws a compile time error, not a runtime error:
I think your issues may just like in the semantics of how Type checking works in JavaScript / Typescript.