TypeScript: Unterschied zwischen den Versionen

Aus CodicaTipps
Zur Navigation springen Zur Suche springen
Markierungen: Mobile Bearbeitung Mobile Web-Bearbeitung
 
(9 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 51: Zeile 51:
  
 
Im Terminal:
 
Im Terminal:
 +
  mkdir $PROJEKT_VERZEICHNIS
 +
  cd $PROJEKT_VERZEICHNIS
 
   npm init
 
   npm init
 
   npm install --save-dev ts-jest typescript jest @types/jest ts-node
 
   npm install --save-dev ts-jest typescript jest @types/jest ts-node
Zeile 73: Zeile 75:
 
Im Terminal
 
Im Terminal
 
   npx ts-jest config:init
 
   npx ts-jest config:init
 +
 +
In jest.config.js folgende Zeile in <code>module.exports={</code> einfügen:
 +
  testPathIgnorePatterns:["/node_modules/","/dist/"],
 +
 +
Einrichten von [[git]]. Erzeugen der Datei <code>.gitignore</code> im Projektverzeichnis:
 +
  node_modules/
 +
  dist/
 +
 +
Initialisierung und erster Commit:
 +
  git init
 +
  git status
 +
  git add .
 +
  git commit
  
 
==== Beispiel für Kommandozeilen-Programm in Typescript ====
 
==== Beispiel für Kommandozeilen-Programm in Typescript ====
Zeile 92: Zeile 107:
 
     "test:watch": "jest --watch",
 
     "test:watch": "jest --watch",
 
     "build": "tsc",
 
     "build": "tsc",
     "dev:version": "nodemon --watch 'src/**/*.ts' --exec 'ts-node' 'src/index.ts' -- '--version'"
+
     "dev:version": "nodemon --watch 'src/**/*.ts' --exec 'ts-node' 'src/index.ts' -- '--version'"
 
   },
 
   },
 +
 +
APPNAME muss dabei durch den Namen des Kommandozeilenprogramms ersetzt werden.
 +
 
In src/index.ts
 
In src/index.ts
 
    
 
    
Zeile 110: Zeile 128:
 
In <code>tsconfig.json</code>:
 
In <code>tsconfig.json</code>:
 
     "types": ["jest","node"],
 
     "types": ["jest","node"],
 +
 +
 +
Statt commander kann man z.B. auch
 +
* https://www.npmjs.com/package/@rushstack/ts-command-line
 +
* [https://yargs.js.org/docs/ yargs]
 +
* [https://github.com/mdbetancourt/soly soly], sehr gute TypeScript-Unterstützung, aber wohl nicht gepflegt
 +
nutzen
  
 
=== TypeScript literals ohne einen bestimmten String ===
 
=== TypeScript literals ohne einen bestimmten String ===
Zeile 134: Zeile 159:
 
* '''[https://github.com/gajus/slonik Slonik]''' nutzt neuere Features von ES6 und kann daher auch gut mit TypeScript genutzt werden.
 
* '''[https://github.com/gajus/slonik Slonik]''' nutzt neuere Features von ES6 und kann daher auch gut mit TypeScript genutzt werden.
 
** Darauf aufbauend ermöglicht [https://www.npmjs.com/package/@slonik/typegen?activeTab=readme @slonik/typegen] automatisch TypeScript-Interfaces zu erzeugen, mit deren Hilfe das Ergebnis von SELECT-Querys typsicher verwendet werden kann.
 
** Darauf aufbauend ermöglicht [https://www.npmjs.com/package/@slonik/typegen?activeTab=readme @slonik/typegen] automatisch TypeScript-Interfaces zu erzeugen, mit deren Hilfe das Ergebnis von SELECT-Querys typsicher verwendet werden kann.
 +
** [https://blog.logrocket.com/improving-type-safety-postgresql-slonik/ Beispielanwendung mit Slonik, TypeScript und Express]
  
 
=== TypeScript - Laufzeit-Typ-Überprüfung ===
 
=== TypeScript - Laufzeit-Typ-Überprüfung ===
Zeile 157: Zeile 183:
 
Siehe auch  
 
Siehe auch  
  
 +
* [https://github.com/sumukhbarve/monoduck/tree/main/src/tapiduck tAPIDuck]
 +
* tRPC
 
* [https://www.npmjs.com/package/ts-auto-guard?activeTab=readme ts-auto-guard]
 
* [https://www.npmjs.com/package/ts-auto-guard?activeTab=readme ts-auto-guard]
 
* [https://www.npmjs.com/package/typescript-json-validator typescript-json-validator]
 
* [https://www.npmjs.com/package/typescript-json-validator typescript-json-validator]

Aktuelle Version vom 18. Mai 2024, 19:56 Uhr

TypeScript ist eine JavaScript-Weiterentwicklung, die Typsicherheit bietet. TypeScript wird in JavaScript übersetzt.

TypeScript und Node.js

Allgemein

Siehe

Bauen eines npm-Moduls mit TypeScript

Siehe

TypeScript und Jest

 npm install --save-dev jest ts-jest @types/jest
 npx ts-jest config:init

Außerdem muss man in der tsconfig.json in compilerOptions => types noch "jest" aufnehmen. Das kann dann so aussehen:

 "types": ["node","jest"],

Siehe

TypeScript und einzelne Anwendungsfelder

TypeScript und Node.js

Das Aufsetzen eines Nodejs-Projekts mit TypeScript wird bei Khalil Stemmer geschildert.

Wie man eine Library mit TypeScript baut wird von Mean geschildert.

Ein Kommandozeilen-Script in TypeScript auf Basis von Node.js zeigt


Beispiel für Library in Typescript

Siehe

Im Terminal:

 mkdir $PROJEKT_VERZEICHNIS
 cd $PROJEKT_VERZEICHNIS
 npm init
 npm install --save-dev ts-jest typescript jest @types/jest ts-node
 npx tsc --init

Anpassen von package.json

 "main":"./dist/index.js",
 "scripts": {
   "test": "jest",
   "test:watch": "jest --watch",
   "build": "tsc"
 },
  

Anpassen von tsconfig.json

 "rootDir": "./src",                                 
 "types": ["jest"],
 "declaration": true,
 "declarationMap": true,
 "outDir": "./dist",
   

Im Terminal

 npx ts-jest config:init

In jest.config.js folgende Zeile in module.exports={ einfügen:

 testPathIgnorePatterns:["/node_modules/","/dist/"],

Einrichten von git. Erzeugen der Datei .gitignore im Projektverzeichnis:

 node_modules/
 dist/

Initialisierung und erster Commit:

 git init
 git status
 git add .
 git commit

Beispiel für Kommandozeilen-Programm in Typescript

Zuerst Schritte ausführen wie in TypeScript#Beispiel_f.C3.BCr_Library_in_Typescript.

Dann commander installieren

 npm install --save commander @commander-js/extra-typings

nodemon installieren:

 npm install --save-dev nodemon @types/node

In package.json

 "bin": {
   "APPNAME":"./dist/index.js"
 },
 "scripts": {
   "test": "jest",
   "test:watch": "jest --watch",
   "build": "tsc",
   "dev:version": "nodemon --watch 'src/**/*.ts' --exec 'ts-node' 'src/index.ts' -- '--version'"
  },

APPNAME muss dabei durch den Namen des Kommandozeilenprogramms ersetzt werden.

In src/index.ts

 #!/usr/bin/env node
 import { program } from "commander";
 const pkg = require("../package.json");
 program
   .name(pkg.name)
   .version(pkg.version)
   .description(pkg.description)
   .action(()=>{
     console.log("hi")
   })
   .parse();

In tsconfig.json:

   "types": ["jest","node"],


Statt commander kann man z.B. auch

nutzen

TypeScript literals ohne einen bestimmten String

Siehe

typensicherer Event-Handling

Siehe

TypeScript und PostgreSQL

TypeScript kann jedes JavaScript/Node.js-Framework für den Zugriff auf PostgreSQL nutzen. Darüber hinaus gibt es weitere Bibliotheken:

TypeScript - Laufzeit-Typ-Überprüfung

Type Script kann zur Kompilierzeit Typensicherheit sicherstellen. Verschiedene Tools können auf Basis von TypeScript-Typen Prüfmethoden erstellen, um zur Laufzeit z.B. ein in JSON eingelesenen Typ auf Übereinstimmung mit dem TypeScript-Typ abzugleichen:

Eine Möglichkeit ist typescript-json-validator:

 npm install --save-dev typescript-json-validator


In src/types/types.ts werden die zu validierenden Typen exportiert.

In der package.json wird unter "scripts" folgender Eintrag hinzugefügt:

     "build:validators": "typescript-json-validator --defaultProps=false --useNamedExport --collection src/types/types.ts && sed -i  -e \"s/export {/export type {/\" -e s/\\\"format\\\":\\\"fast\\\",// -e s/\\\"nullable\\\":true,// -e s/\\\"uniqueItems\\\":true,// -e s/\\\"unicode\\\":true,// src/types/types.validator.ts",

Der sed-Befehl sollte folgende Fehler vermeiden:

  • "Das Argument vom Typ \"{ allErrors: true; coerceTypes: false; format: string; nullable: boolean; unicode: true; uniqueItems: boolean; useDefaults: false; }\" kann dem Parameter vom Typ \"Options\" nicht zugewiesen werden.\n Das Objektliteral kann nur bekannte Eigenschaften angeben, und \"\"format\"\" ist im Typ \"Options\" nicht vorhanden.",
  • Das erneute Exportieren eines Typs erfordert bei Festlegung des Flags \"--isolatedModules\" die Verwendung von \"export type\".",


Siehe auch

Siehe auch

TypeScript REST-API

TypeScript REST-API-Server auf Basis von HAPI

Siehe

mit Authentifizierung

Siehe

TypeScript API from PostgresDB

Siehe

TypeScript API erstellen

Siehe

Weiterführendes

Siehe auch