Disse egenskabsmodifikatorer styrer, om en egenskab er påkrævet og om den kan tilregnes igen.
Optional (?)
ts
{
: ;
?: ;
}
: = { : };
: = { : , : };
() {
u..;
u.?.;
}
Disse egenskabsmodifikatorer styrer, om en egenskab er påkrævet og om den kan tilregnes igen.
?) {
: ;
?: ;
}
: = { : };
: = { : , : };
() {
u..;
u.?.;
}
En valgfri egenskab har typen T | undefined, så compileren tvinger dig til at håndtere det fraværende tilfælde — og forebygger "cannot read property of undefined"-fejl.
interface Point { readonly x: number; readonly y: number; }
const p: Point = { x: 1, y: 2 };
p.x = 5; // ❌ Error: cannot assign to readonly property
// arrays too
const nums: readonly number[] = [1, 2, 3];
nums.push(4); // ❌ push doesn't exist on readonly array
readonly er kun kompileringstid (ingen runtime-håndhævelse), men det dokumenterer og håndhæver uforanderlighed i typesystemet, hvilket fanger utilsigtede mutationer.
interface Config { readonly id: string; tags?: readonly string[]; }
type Frozen = Readonly<User>; // utility type makes ALL props readonly
? modellerer virkelig valgfri data og tvinger null-sikkerhed; readonly udtrykker og håndhæver uforanderlighed (fantastisk til konfiguration, props og forebyggelse af utilsigtet state-mutation).
Begge skubber korrekthedskontrol ind i compileren.