El repositorio de definiciones de TypeScript de alta calidad.
Vea también el sitio web definitelytyped.org, aunque la información en este README está más actualizada.
Vea el Manual de TypeScript.
Este es el método preferido. Solo está disponible para usuarios TypeScript 2.0+. Por ejemplo:
npm install --save-dev @types/node
Los types deberían ser incluidos automaticamente por el compilador. Vea más en el manual.
Para un paquete NPM "foo", Estos typings
estarán en "@types/foo".
Si no puedes encontrar tu paquete, búscalo en TypeSearch.
Si aún no puedes encontrarlo, comprueba si el paquete ya incluye los typings.
Esto es provisto usualmente en el campo "types"
o "typings"
en el package.json
,
o solo busca por cualquier archivo ".d.ts" en el paquete e incluyelo manualmente con un /// <reference path="" />
.
Estos pueden ser utilizados por TypeScript 1.0.
- Typings
NuGet(use las alternativas preferidas, la publicación DT type de nuget ha sido desactivada)- Descarguelo manualmente desde la
master
branch de este repositorio
Tal vez debas añadir manualmente las referencias.
¡DefinitelyTyped solo trabaja gracias a contribuidores como tú!
Antes de compartir tu mejora con el mundo, úselo usted mismo.
Para agregar nuevas funciones puedes usar el module augmentation.
También puedes editar directamente los types en node_modules/@types/foo/index.d.ts
, o copiarlos de ahí y seguir los pasos explicados a continuación.
Añade a tu tsconfig.json
:
"baseUrl": "types",
"typeRoots": ["types"],
(También puedes usar src/types
.)
Crea un types/foo/index.d.ts
que contenga declaraciones del módulo "foo".
Ahora deberías poder importar desde "foo"
a tu código y te enviara a un nuevo tipo de definición.
Entonces compila y ejecuta el código para asegurarte que el tipo de definición en realidad corresponde a lo que suceda en el momento de la ejecución.
Una vez que hayas probado tus definiciones con el código real, haz un PR
luego sigue las instrucciones para editar un paquete existente o
crear un nuevo paquete.
Una vez que hayas probado tu paquete, podrás compartirlo en DefinitelyTyped.
Primero, haz un fork en este repositorio, instala node, y luego ejecuta la npm install
.
cd types/my-package-to-edit
- Haz cambios. Recuerda editar las pruebas.
- También puede que quieras añadirte la sección "Definitions by" en el encabezado del paquete.
- Esto hará que seas notificado (a través de tu nombre de usuario en GitHub) cada vez que alguien haga un pull request o issue sobre el paquete.
- Haz esto añadiendo tu nombre al final de la línea, así como en
// Definitions by: Alice <https://github.com/alice>, Bob <https://github.com/bob>
. - O si hay más personas, puede ser multiline
// Definitions by: Alice <https://github.com/alice> // Bob <https://github.com/bob> // Steve <https://github.com/steve> // John <https://github.com/john>
- Si hay un
tslint.json
, ejecutanpm run lint package-name
. De lo contrario, ejecutatsc
en el directorio del paquete.
Cuando hagas un PR para editar un paquete existente, dt-bot
deberá @-mencionar a los autores previos.
Si no lo hace, puedes hacerlo en el comentario asociado con el PR.
Si eres el autor de la librería, o puedes hacer un pull request a la biblioteca, bundle types en vez de publicarlo en DefinitelyTyped.
Si estás agregando typings para un paquete NPM, crea un directorio con el mismo nombre.
Si el paquete al que le estás agregando typings no es para NPM, asegurate de que el nombre que escojas no genere problemas con el nombre del paquete en NPM.
(Puedes usar npm info foo
para verificar la existencia del paquete foo
.)
Tu paquete debería tener esta estructura:
Archivo | Propósito |
---|---|
index.d.ts | Este contiene los typings del paquete. |
foo-tests.ts | Este contiene una muestra del código con el que se realiza la prueba de escritura. Este código no es ejecutable, pero sí es type-checked. |
tsconfig.json | Este permite ejecutar tsc dentro del paquete. |
tslint.json | Permite linting. |
Generalas ejecutando npm install -g dts-gen
y dts-gen --dt --name my-package-name --template module
.
Ve todas las opciones en dts-gen.
También puedes configurar el tsconfig.json
para añadir nuevos archivos, para agregar un "target": "es6"
(necesitado por las funciones asíncronas), para agregar a la "lib"
, o para agregar la opción de compilación "jsx"
.
Los miembros de DefinitelyTyped frecuentemente monitorean nuevos PRs, pero ten en mente que la cantidad de PRs podrian ralentizar el proceso.
Para un buen paquete de ejemplo, vea base64-js.
- Primero, sigue el consejo del manual.
- Formatear: Ya sea utilizar todo en tabs, o siempre utiliza 4 espacios.
function sum(nums: number[]): number
: UtilizaReadonlyArray
si una funcion no escribe a sus parámetros.interface Foo { new(): Foo; }
: Este define el tipo de objeto que esten nuevos. Probablemente quierasdeclare class Foo { constructor(); }
.const Class: { new(): IClass; }
: Prefiere usar una declaración de claseclass Class { constructor(); }
En vez de una nueva constante.getMeAT<T>(): T
: Si un tipo de parámetro no aparece en los tipos de ningún parámetro, no tienes una función genérica, solo tienes un afirmación del tipo disfrazado. Prefiera utilizar una afirmación de tipo real, p.ej.getMeAT() as number
. Un ejemplo donde un tipo de parámetro es aceptable:function id<T>(value: T): T;
. Un ejemplo donde no es aceptable:function parseJson<T>(json: string): T;
. Una excepción:new Map<string, number>()
está bien.- Utilizando los tipos
Function
yObject
casi nunca es una buena idea. En 99% de los casos es posible especificar un tipo más especifico. Los ejemplos son(x: number) => number
para funciones y{ x: number, y: number }
para objetos. Si no hay certeza en lo absoluto del tipo,any
es la opción correcta, noObject
. Si el único hecho conocido sobre el tipo es que es un objecto, usa el tipoobject
, noObject
o{ [key: string]: any }
. var foo: string | any
: Cuando es usadoany
en un tipo de unión, el tipo resultante todavía esany
. Así que mientras la porciónstring
de este tipo de anotación puede verse útil, de hecho, no ofrece ningún typechecking adicional más que un simpleany
. Dependiendo de la intención, una alternativa aceptable puede serany
,string
, ostring | object
.
Cuando un paquete bundles sus propios tipos, estos tipos deberán ser removidos de DefinitelyTyped para evitar que generen confusión.
Se puede remover ejecutando npm run not-needed -- typingsPackageName asOfVersion sourceRepoURL [libraryName]
.
typingsPackageName
: Este es el nombre del directorio que tienes que eliminar.asOfVersion
: Un stub será publicado a@types/foo
con esta versión. Debería ser más grande que cualquier versión publicada actualmente.sourceRepoURL
: Esto debería señalar el repositorio que contiene los typings.libraryName
: Un nombre descriptivo de la librería, p.ej. "Angular 2" en vez de "angular2". (Si es omitido, será idéntico a "typingsPackageName".)
Cualquier otro paquete en DefinitelyTyped que referencie el paquete eliminado deberá ser actualizado para referenciar los tipos bundled. para hacer esto, añade package.json
con "dependencies": { "foo": "x.y.z" }
.
Si un paquete nunca estuvo en DefinitelyTyped, no será necesario añadirlo a notNeededPackages.json
.
Para realizar el lint a un paquete, solo añade tslint.json
al paquete que contiene { "extends": "dtslint/dt.json" }
. Todos los paquetes nuevos deberán pasar por el proceso de linted.
Si el tslint.json
deshabilita algunas reglas esto se debe a que aún no se ha acomodado. Por ejemplo:
{
"extends": "dtslint/dt.json",
"rules": {
// This package uses the Function type, and it will take effort to fix.
"ban-types": false
}
}
(Para indicar que la regla lint realmente no es utilizada, usa // tslint:disable rule-name
o mejor, //tslint:disable-next-line rule-name
.)
Para afirmar que una expresión es de un tipo dado, utilice $ExpectType
. Para afirmar que una expresión causa un error de compilación, utilice $ExpectError
.
// $ExpectType void
f(1);
// $ExpectError
f("one");
Para más detalles, vea el dtslint readme.
Realiza una prueba ejecutando npm run lint package-name
donde package-name
es el nombre de tu paquete.
Este script utiliza dtslint.