Heim >Web-Frontend >js-Tutorial >【Grundlagen des Vorstellungsgesprächs】 Häufige Fragen im Vorstellungsgespräch mit TypeScript
github: https://github.com/Jessie-jzn
Website:https://www.jessieontheroad.com/
1. Statische Typprüfung
Der Hauptvorteil von TypeScript ist die statische Typprüfung, die dabei hilft, häufige Fehler während der Kompilierungsphase und nicht zur Laufzeit zu erkennen. Dies erhöht die Zuverlässigkeit und Stabilität des Codes.
2. Verbesserte Erfahrung bei der Codebearbeitung
Das Typsystem von TypeScript ermöglicht eine genauere Codevervollständigung, Refactoring, Navigation und Dokumentationsfunktionen in Editoren und steigert so die Entwicklungseffizienz erheblich.
3. Verbesserte Wartbarkeit des Codes
Typdeklarationen erleichtern das Verständnis von Codeabsichten und -struktur, was besonders in Teamentwicklungsumgebungen von Vorteil ist.
4. Erweiterte Sprachfunktionen
TypeScript unterstützt erweiterte Funktionen, die in JavaScript nicht vorhanden sind, wie z. B. Schnittstellen, Aufzählungen und Generika, und erleichtert so die Entwicklung von strukturierterem und skalierbarerem Code.
5. Bessere Werkzeugunterstützung
TypeScript bietet verschiedene Compiler-Optionen zur Optimierung des generierten JavaScript-Codes und unterstützt verschiedene JS-Umgebungen durch Kompilieren von TypeScript zu kompatiblem JavaScript.
TypeScript | JavaScript | |
---|---|---|
Type System | Static typing with compile-time type checks. Types can be specified for variables, function parameters, and return values. | Dynamic typing with runtime type checks, which can lead to type-related runtime errors. |
Type Annotations | Supports type annotations to explicitly define types. E.g., let name: string = "Alice"; | No type annotations. Types are determined at runtime. |
Compilation | Requires compilation to JavaScript. TypeScript compiler checks for type errors and generates equivalent JavaScript code. | Runs directly in browsers or Node.js without a compilation step. |
Object-Oriented Programming | Richer OOP features such as classes, interfaces, abstract classes, and access modifiers. | Basic OOP features with prototype-based inheritance. |
Advanced Features | Includes all ES6 and ES7 features, plus additional features like generics, enums, and decorators. | Supports ES6 and later standards, but lacks some of the advanced features provided by TypeScript. |
Generika ermöglichen es Funktionen, Klassen und Schnittstellen, mit jedem Typ zu arbeiten und gleichzeitig die Typsicherheit zu gewährleisten.
Beispiel:
function identity<T>(arg: T): T { return arg; } const numberIdentity = identity<number>(42); const stringIdentity = identity<string>("Hello");
In diesem Beispiel verwendet die Identitätsfunktion ein generisches
let anyVar: any; let unknownVar: unknown; anyVar = 5; anyVar.toUpperCase(); // No compile-time error, but might cause runtime error unknownVar = "Hello"; if (typeof unknownVar === "string") { unknownVar.toUpperCase(); // Type check ensures safety }
const obj = { name: "John" }; obj.name = "Doe"; // Allowed interface User { readonly id: number; name: string; } const user: User = { id: 1, name: "John" }; user.name = "Doe"; // Allowed user.id = 2; // Error, `id` is readonly
Dekoratoren sind eine spezielle TypeScript-Funktion, die das Hinzufügen von Metadaten oder das Ändern von Klassen, Methoden, Eigenschaften oder Parametern ermöglicht.
Typen:
Beispiele:
function sealed(constructor: Function) { Object.seal(constructor); Object.seal(constructor.prototype); } @sealed class Greeter { greeting: string; constructor(message: string) { this.greeting = message; } greet() { return `Hello, ${this.greeting}`; } }
function logMethod(target: any, propertyName: string, descriptor: PropertyDescriptor) { const originalMethod = descriptor.value; descriptor.value = function (...args: any[]) { console.log(`Method ${propertyName} called with args: ${JSON.stringify(args)}`); return originalMethod.apply(this, args); }; } class Calculator { @logMethod add(a: number, b: number): number { return a + b; } }
Verwendung:
Dekoratoren werden aktiviert, indem „experimentalDecorators“ in tsconfig.json auf „true“ gesetzt wird.
Schnittstelle und Typ werden beide zum Definieren von Objekttypen verwendet, weisen jedoch einige Unterschiede auf:
interface | type | |
---|---|---|
Basic Usage | Defines the shape of objects, including properties and methods. | Defines primitive types, object types, union types, intersection types, etc. |
Extension | Supports declaration merging. Multiple declarations of the same interface are automatically merged. | Does not support declaration merging. |
Union and Intersection Types | Not supported. | Supports union (` |
Primitive Type Aliases | Not supported. | Supports aliasing primitive types. |
Mapped Types | Not supported. | Supports mapped types. |
Class Implementation | Supports class implementation using implements. | Does not support direct class implementation. |
Typ
Das obige ist der detaillierte Inhalt von【Grundlagen des Vorstellungsgesprächs】 Häufige Fragen im Vorstellungsgespräch mit TypeScript. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!