„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Vorsichtsmaßnahmen bei der Verwendung von readonly in TypeScript

Vorsichtsmaßnahmen bei der Verwendung von readonly in TypeScript

Veröffentlicht am 21.08.2024
Durchsuche:376

Cautions When Using readonly in TypeScript

Die Grundlage der schreibgeschützten Eigenschaft

In Type Script können Sie die Eigenschaften eines Objekts schreibgeschützt machen.

const person: { readonly name: string  } = { name: 'Mike' }

person.name = 21;
// → Cannot assign to 'name' because it is a read-only property.

⚠️① schreibgeschützt ist nur zur Kompilierungszeit

Im kompilierten JavaScript-Code wird die schreibgeschützte Deklaration entfernt, sodass sie zur Laufzeit nicht als Fehler erkannt wird.

⚠️② readonly ist nicht rekursiv.

const person: {
  readonly name: string;
  readonly academicBackground: {
    primarySchool: string
  }
} = {
  name: 'Mike',
  academicBackground: {
    primarySchool: 'School A'
  }
}

person.academicBackground.primarySchool = 'School B'
// You can change `person.academicBackground.primarySchool`

Wenn Sie es schreibgeschützt machen möchten, müssen Sie auch „readonly“ für PrimarySchool festlegen.

const person: {
  readonly name: string;
  readonly academicBackground: {
    readonly primarySchool: string
  }
} = {
  name: 'Mike',
  academicBackground: {
    primarySchool: 'School A'
  }
}

person.academicBackground.primarySchool = 'School B'
// → Cannot assign to 'primarySchool' because it is a read-only property.

Schreibgeschützt

Wenn die Anzahl der Eigenschaften zunimmt, wird das Hinzufügen von schreibgeschützten Eigenschaften zu jeder einzelnen umständlich und erhöht die Codemenge.
Sie können das Refactoring mithilfe von Readonly durchführen.

const obj: {
  readonly a : string;
  readonly b: string;
  readonly c: string;
  readonly d: string;
} = {
  a: 'a',
  b: 'b',
  c: 'c',
  d: 'd'
}

// ↓

const obj: Readonly = {
  a: 'a',
  b: 'b',
  c: 'c',
  d: 'd'
}

Viel Spaß beim Programmieren☀️

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/noah-00/cautions-when-using-readonly-in-typescript-22d7?1 Bei Verstößen wenden Sie sich bitte an [email protected], um ihn zu löschen
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3