aburtang@lemmy.world to Programmer Humor@lemmy.ml · 7 days agoEvil Oneslemmy.worldimagemessage-square76fedilinkarrow-up11Karrow-down132
arrow-up1970arrow-down1imageEvil Oneslemmy.worldaburtang@lemmy.world to Programmer Humor@lemmy.ml · 7 days agomessage-square76fedilink
minus-squaremasterspace@lemmy.calinkfedilinkEnglisharrow-up4arrow-down2·edit-26 days agoI think that might be user error as I can’t recreate that:
minus-squarepooberbee (they/she)@lemmy.mllinkfedilinkarrow-up2arrow-down1·6 days agoYeah, you would get a runtime error calling that member without checking that it exists.
minus-squaremasterspace@lemmy.calinkfedilinkEnglisharrow-up1·edit-22 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.