A const
assertion is a special type assertion that uses the const
keyword instead of a specific type name. When using a const
assertion on an object literal expression, all properties will become readonly
properties and no literal types within the expression will be widened.
const ORIGIN = { x: 0, y: 0 } // works ORIGIN.x = 1
If you don't want user able to change it:
const ORIGIN: { readonly x: number, readonly y: number } = { x: 0, y: 0 } // Typescript complian // Cannot assign to 'x' because it is a read-only property. ORIGIN.x = 1
Better way:
const ORIGIN = { x: 0, y: 0 } as const // Typescript complian // Cannot assign to 'x' because it is a read-only property. ORIGIN.x = 1
But `as const` doesn't enforce in runtime. If we do want to prevent mutate the object, we can do:
const ORIGIN = Object.freeze({ x: 0, y: 0 } as const) // Typescript complian // Cannot assign to 'x' because it is a read-only property. ORIGIN.x = 1
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。