使用 readonly
所装饰的数据, 无论为[变量|常量|属性]
均无法修改, 只能读取。
1 2 3
| const nums = [1, 2, 3]
nums[0] = 123
|
data:image/s3,"s3://crabby-images/b747f/b747f2b69a6b8a8cd3be9d55845e1971188be525" alt="类型可修改"
使用 as const
添加 readonly
特性
1 2 3
| const nums = [1, 2, 3] as const
nums[0] = 123
|
data:image/s3,"s3://crabby-images/cfadc/cfadc223e3cc5ed53c95cc3e2465c2c45a5c016a" alt="`readonly` 特性"
readonly
可以推导到具体的值, 例如
data:image/s3,"s3://crabby-images/130aa/130aae074d8e29b512d24a7a863eedf31d2703ba" alt="类型推导"
1 2 3 4 5
| const aBoy = { name: '小明', age: 18, }
|
前者可以单独为某一个属性添加, 后者为所有的属性添加
1 2 3 4 5 6 7 8 9
| const aBoy = { name: '小明' as const, age: 18 as const, }
const aBoy2 = { name: '小明', age: 18, } as const
|
data:image/s3,"s3://crabby-images/f711c/f711ce6acaf59308f841df91ac9acdae7cbc8623" alt="redaonly设置"
🌰 举个例子
包括但不限于 hiddens
过滤, 配合 readonly
还能实现更高级 获取器 getter
设置器 setter
操作并返回最终类型
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
| abstract class BaseModel<D extends Record<string, unknown>> { abstract readonly hiddens: Array<keyof D> constructor(private data: D) {}
toJSON() { const { hiddens, data } = this const keys = Object.keys(data).filter((key) => !hiddens.includes(key)) const entries = keys.map((key) => [key, data[key]])
const newData = Object.fromEntries(entries)
return newData as Omit<D, this['hiddens'][number]> } }
class BoyModel extends BaseModel<{ name: string age: number xx: string }> { hiddens = ['xx' as const] }
|
实例化模型后可得
data:image/s3,"s3://crabby-images/c55dd/c55ddab34289dc49a987bca0ab423a5f853ff9c9" alt="Alt text"