Leider sind diese Dinge derzeit nicht sehr gut dokumentiert, aber selbst wenn Sie sie zum Laufen bringen konnten, gehen wir Ihre Konfiguration durch, damit Sie verstehen, was jedes Teil tut und wie es sich darauf bezieht, wie Typoskript Typisierungen verarbeitet und lädt.
Lassen Sie uns zuerst den Fehler durchgehen, den Sie erhalten:
error TS2688: Cannot find type definition file for 'lodash'.
Dieser Fehler ist eigentlich nicht auf Ihre Importe oder Referenzen oder Ihren Versuch zurückzuführen, lodash irgendwo in Ihren ts-Dateien zu verwenden. Vielmehr ist es aus einem Missverständnis zu kommen , wie die verwenden typeRoots
und types
Eigenschaften, so geht sie in ein wenig mehr Details über diese.
Das Besondere an typeRoots:[]
und types:[]
Eigenschaften ist, dass es sich NICHT um allgemeine Methoden zum Laden beliebiger declaration ( *.d.ts
) - Dateien handelt.
Diese beiden Eigenschaften stehen in direktem Zusammenhang mit der neuen TS 2.0-Funktion, mit der Typisierungsdeklarationen aus NPM-Paketen verpackt und geladen werden können .
Dies ist sehr wichtig zu verstehen, dass diese nur mit Ordnern im NPM-Format funktionieren (dh einem Ordner, der eine package.json oder index.d.ts enthält ).
Der Standardwert für typeRoots
ist:
{
"typeRoots" : ["node_modules/@types"]
}
Standardmäßig bedeutet dies, dass Typoskript in den node_modules/@types
Ordner verschoben wird und versucht, jeden dort gefundenen Unterordner als npm-Paket zu laden .
Es ist wichtig zu verstehen, dass dies fehlschlägt, wenn ein Ordner keine npm-paketähnliche Struktur hat.
Dies ist, was in Ihrem Fall passiert, und die Quelle Ihres anfänglichen Fehlers.
Sie haben typeRoot auf Folgendes umgestellt:
{
"typeRoots" : ["./typings"]
}
Dies bedeutet, dass Typoskript jetzt den ./typings
Ordner nach Unterordnern durchsucht und versucht, jeden gefundenen Unterordner als npm-Modul zu laden.
typeRoots
Stellen wir uns also vor, Sie hätten gerade ein Setup, auf das Sie verweisen ./typings
könnten , aber noch kein types:[]
Eigenschafts-Setup. Sie würden wahrscheinlich diese Fehler sehen:
error TS2688: Cannot find type definition file for 'custom'.
error TS2688: Cannot find type definition file for 'global'.
Dies liegt daran , tsc
wird die Scan - ./typings
Ordner und die Suche nach den Unterordner custom
und global
. Es wird dann versucht, diese als Typisierung vom Typ npm zu interpretieren, aber es gibt keine index.d.ts
oder package.json
in diesen Ordnern, und Sie erhalten den Fehler.
Lassen Sie uns nun ein wenig über die types: ['lodash']
Eigenschaft sprechen, die Sie festlegen. Was macht das? Standardmäßig lädt Typoskript alle Unterordner, die es in Ihrem findet typeRoots
. Wenn Sie eine types:
Eigenschaft angeben , werden nur diese bestimmten Unterordner geladen.
In Ihrem Fall weisen Sie es an, den ./typings/lodash
Ordner zu laden, aber er existiert nicht. Deshalb erhalten Sie:
error TS2688: Cannot find type definition file for 'lodash'
Fassen wir also zusammen, was wir gelernt haben. Typescript 2.0 wurde eingeführt typeRoots
und types
zum Laden von Deklarationsdateien in npm-Paketen . Wenn Sie benutzerdefinierte Typisierungen oder einzelne lose d.ts
Dateien haben, die nicht in einem Ordner enthalten sind, der den Konventionen des npm-Pakets entspricht, sind diese beiden neuen Eigenschaften nicht das, was Sie verwenden möchten. Typescript 2.0 ändert nicht wirklich, wie diese verbraucht werden. Sie müssen diese Dateien nur auf eine der vielen Standardmethoden in Ihren Kompilierungskontext aufnehmen:
Direkt in eine .ts
Datei aufnehmen:
///<reference path="../typings/custom/lodash.d.ts" />
Einschließlich ./typings/custom/lodash.d.ts
in Ihrem files: []
Eigentum.
Einschließen ./typings/index.d.ts
in Ihre files: []
Eigenschaft (die dann rekursiv die anderen Typisierungen enthält.
Hinzufügen ./typings/**
zu Ihremincludes:
Anhand dieser Diskussion können Sie hoffentlich feststellen, warum die Änderungen, die Sie an Ihren tsconfig.json
vorgenommenen Dingen vorgenommen haben, wieder funktionieren.
BEARBEITEN:
Eine Sache, die ich vergessen habe zu erwähnen, ist, dass typeRoots
und types
Eigenschaft wirklich nur zum automatischen Laden globaler Deklarationen nützlich sind .
Zum Beispiel, wenn Sie
npm install @types/jquery
Wenn Sie die Standard-tsconfig verwenden, wird das Paket jquery types automatisch geladen und $
ist in allen Ihren Skripten verfügbar, ohne dass Sie weitere Schritte ausführen müssen ///<reference/>
oderimport
Die typeRoots:[]
Immobilie soll von weiteren Standorten hinzufügen , wo Typ - Pakete werden automatisch geladen frrom werden.
Der types:[]
Hauptanwendungsfall der Eigenschaft besteht darin, das automatische Ladeverhalten zu deaktivieren (indem Sie es auf ein leeres Array setzen) und dann nur bestimmte Typen aufzulisten, die Sie global einschließen möchten.
Die andere Möglichkeit, Typpakete aus den verschiedenen zu laden, typeRoots
ist die Verwendung der neuen ///<reference types="jquery" />
Direktive. Beachten Sie die types
statt path
. Dies ist wiederum nur für globale Deklarationsdateien nützlich, normalerweise solche, die dies nicht tun import/export
.
Hier ist eines der Dinge, die Verwirrung stiften typeRoots
. Denken Sie daran, ich sagte, dass typeRoots
es um die globale Einbeziehung von Modulen geht. Ist @types/folder
aber auch an der Standardmodulauflösung beteiligt (unabhängig von Ihrer typeRoots
Einstellung).
Insbesondere explizit den Import Module umgeht immer alle includes
, excludes
, files
, typeRoots
und types
Optionen. Also, wenn Sie tun:
import {MyType} from 'my-module';
Alle oben genannten Eigenschaften werden vollständig ignoriert. Die relevanten Eigenschaften während Modul Auflösung sind baseUrl
, paths
und moduleResolution
.
Grundsätzlich bei der Verwendung von node
Modul - Auflösung, wird es die Suche nach einem Dateinamen beginnen my-module.ts
, my-module.tsx
, my-module.d.ts
in dem Ordner starten , auf dem die baseUrl
Konfiguration.
Wenn die Datei nicht gefunden wird, sucht sie nach einem Ordner mit dem Namen my-module
und sucht dann nach einem package.json
mit einer typings
Eigenschaft. Wenn sich darin eine Eigenschaft befindet package.json
oder nicht, die typings
angibt, welche Datei geladen werden soll, wird index.ts/tsx/d.ts
in diesem Ordner gesucht .
Wenn dies immer noch nicht erfolgreich ist, wird im node_modules
Ordner, der bei Ihnen beginnt, nach denselben Dingen gesucht baseUrl/node_modules
.
Wenn diese nicht gefunden werden, wird außerdem nach baseUrl/node_modules/@types
denselben Dingen gesucht .
Wenn es immer noch nichts findet , wird es beginnen , das übergeordnete Verzeichnis zu gehen und suchen node_modules
und node_modules/@types
dort. Es wird die Verzeichnisse weiter durchsuchen, bis es das Stammverzeichnis Ihres Dateisystems erreicht (sogar Knotenmodule außerhalb Ihres Projekts).
Eine Sache, die ich hervorheben möchte, ist, dass die Modulauflösung alle von typeRoots
Ihnen festgelegten Einstellungen vollständig ignoriert . Wenn Sie also konfiguriert haben typeRoots: ["./my-types"]
, wird dies während der expliziten Modulauflösung nicht durchsucht. Es dient nur als Ordner, in dem Sie globale Definitionsdateien ablegen können, die Sie der gesamten Anwendung zur Verfügung stellen möchten, ohne dass Sie sie erneut importieren oder referenzieren müssen.
Zuletzt können Sie das Modulverhalten mit Pfadzuordnungen (dh der paths
Eigenschaft) überschreiben . So habe ich zum Beispiel erwähnt, dass typeRoots
beim Versuch, ein Modul aufzulösen , keine benutzerdefinierten Benutzer berücksichtigt werden. Aber wenn Sie möchten, können Sie dieses Verhalten folgendermaßen ausführen:
"paths" :{
"*": ["my-custom-types/*", "*"]
}
Versuchen Sie für alle Importe, die mit der linken Seite übereinstimmen, den Import wie auf der rechten Seite zu ändern, bevor Sie versuchen, ihn einzuschließen ( *
die rechte Seite repräsentiert Ihre anfängliche Importzeichenfolge. Wenn Sie beispielsweise importieren:
import {MyType} from 'my-types';
Es würde zuerst den Import versuchen, als ob Sie geschrieben hätten:
import {MyType} from 'my-custom-types/my-types'
Und wenn es dann nicht gefunden wird, versucht es es erneut ohne das Präfix (das zweite Element im Array ist genau *
das, was den ersten Import bedeutet.
Auf diese Weise können Sie zusätzliche Ordner hinzufügen, um nach benutzerdefinierten Deklarationsdateien oder sogar nach benutzerdefinierten .ts
Modulen zu suchen , die Sie verwenden möchten import
.
Sie können auch benutzerdefinierte Zuordnungen für bestimmte Module erstellen:
"paths" :{
"*": ["my-types", "some/custom/folder/location/my-awesome-types-file"]
}
Dies würde dich tun lassen
import {MyType} from 'my-types';
Aber dann lesen Sie diese Typen aus some/custom/folder/location/my-awesome-types-file.d.ts
paths
und wie unterscheidet es sichinclude
zum Zwecke der Eingabe?"paths" :{ "my-types": ["some/custom/folder/location/my-awesome-types-file"] }
?Bearbeiten: veraltet. Lesen Sie die Antwort oben.
Ich verstehe das immer noch nicht, aber ich habe eine Lösung gefunden. Verwenden Sie Folgendes
tsconfig.json
:Entfernen Sie
typings.json
und alles unter Ordnertypings
außerlodash.d.ts
. Entfernen Sie auch alle///...
Referenzenquelle
"*": ["./types/*"]
Diese Zeile in tsconfig-Pfaden reparierte alles nach 2 Stunden Kampf.Typ ist der Ordnername, der neben node_module dh in der Ebene der sitzt Client - Ordner (oder src - Ordner)
types/third-party-lib/index.d.ts
index.d.ts hat
declare module 'third-party-lib';
Hinweis: Die obige Konfiguration ist eine unvollständige Konfiguration, um eine Vorstellung davon zu geben, wie sie mit Typen, Pfaden, Ein- und Ausschlüssen aussieht.
quelle
Ich weiß, dass dies eine alte Frage ist, aber die Typoskript-Werkzeuge haben sich ständig geändert. Ich denke, die beste Option an dieser Stelle ist, sich nur auf die Pfadeinstellungen "include" in tsconfig.json zu verlassen.
Sofern Sie keine besonderen Änderungen vornehmen, werden standardmäßig alle * .ts- und alle * .d.ts-Dateien unter
src/
automatisch eingeschlossen. Ich denke, dies ist der einfachste / beste Weg, um benutzerdefinierte Typdeklarationsdateien einzuschließen, ohnetypeRoots
und anzupassentypes
.Referenz:
quelle
Ich möchte einige meiner jüngsten Beobachtung teilen die detaillierte Beschreibung finden wir erweitern oben . Zunächst ist zu beachten, dass VS Code häufig unterschiedliche Meinungen darüber hat, wie Dinge zu tun sind.
Sehen wir uns ein Beispiel an, an dem ich kürzlich gearbeitet habe:
src / app / components / plot-plotly / plot-plotly.component.ts:
VS Code kann sich beschweren, dass:
No need to reference "plotly.js", since it is imported. (no-reference import) tslint(1)
Wenn wir das Projekt starten, wird es fehlerfrei kompiliert. Wenn wir diese Zeile jedoch entfernen, wird beim Start der folgende Fehler angezeigt:
ERROR in src/app/components/plot-plotly/plot-plotly.component.ts:19:21 - error TS2503: Cannot find namespace 'plotly'.
Die gleiche Fehlermeldung wird angezeigt, wenn wir die platzieren
reference types
Direktive nach den import-Anweisungen platzieren.Wichtig : Das
/// <reference types="plotly.js" />
muss sich auf der Vorderseite der Typenskriptdatei befinden! Siehe zugehörige Dokumentation: LinkIch empfehle außerdem, die Dokumentation in der Datei tsconfig.json und im Abschnitt typeRoot zu lesen: link
Die obige Referenzrichtlinie funktioniert in folgendem Szenario:
types / plotly.js / index.d.ts: ( Link )
UND
tsconfig.json:
Hinweis : In der obigen Konfiguration bedeuten die beiden "plotly.js" zwei verschiedene Ordner und Dateien (Bibliothek / Definition). Der Import gilt für den Ordner "node_modules / plotly.js" (hinzugefügt von
npm install plotly.js
), während der Verweis für types / plotly.js gilt.Damit mein Projekt die VS-Code-Beschwerden und die Mehrdeutigkeit der "zwei" plotly.js beheben kann, habe ich die folgende Konfiguration erhalten:
DevDeps auf meinem System:
quelle