Criação de arquivos .d.ts a partir de arquivos .js

Com o TypeScript 3.7, TypeScript adicionou suporte para gerar arquivos .d.ts de JavaScript usando a sintaxe JSDoc.

Essa configuração significa que você pode ter a experiência de editores habilitados para TypeScript sem portar seu projeto para TypeScript ou ter que manter arquivos .d.ts em sua base de código. TypeScript suporta a maioria das tags JSDoc, você pode encontrar a referência aqui.

Configurando seu projeto para emitir arquivos .d.ts

Para adicionar a criação de arquivos .d.ts em seu projeto, você precisará realizar até quatro etapas:

  • Adicione TypeScript às suas dependências de desenvolvimento
  • Adicione um tsconfig.json para configurar o TypeScript
  • Execute o compilador TypeScript para gerar os arquivos d.ts correspondentes para arquivos JS
  • (opcional) Edite seu package.json para fazer referência aos tipos

Adicionando TypeScript

Você pode aprender como fazer isso em nossa página de instalação.

TSConfig

O TSConfig é um arquivo jsonc que configura ambos os sinalizadores do compilador e declara onde encontrar os arquivos. Neste caso, você vai querer um arquivo como o seguinte:

json
{
// Mude isso para corresponder ao seu projeto
include: ["src/**/*"],
compilerOptions: {
// Diz para o TypeScript ler arquivos JS.
// Normalmente, seriam ignorados como arquivos fonte
allowJs: true,
// Gerar arquivos d.ts
declaration: true,
// A compilação só gerará arquivos
// d.ts na saída
emitDeclarationOnly: true,
// Tipos devem ir neste diretório.
// Remover isso colocará arquivos .d.ts
// ao lado dos arquivos .js
outDir: "dist",
},
}

Você pode aprender mais sobre as opções na referência tsconfig. Uma alternativa ao uso de um arquivo TSConfig é a CLI, este é o mesmo comportamento de um comando CLI.

sh
npx typescript src/**/*.js --declaration --allowJs --emitDeclarationOnly --outDir types

Execute o compilador

Você pode aprender como fazer isso em nossa página de instalação. Você quer ter certeza de que esses arquivos estão incluídos em seu pacote se você tiver os arquivos .gitignore em seu projeto.

Editando o package.json

TypeScript replica a resolução do Node para módulos em um package.json, com uma etapa adicional para localizar arquivos .d.ts. A grosso modo, a resolução verificará primeiro o campo opcional "types", depois o campo "main" e, finalmente, tentará index.d.ts na raiz.

Package.json Localização do padrão .d.ts
Sem campos “types” field checa “main”, então index.d.ts
“types”: “main.d.ts” main.d.ts
“types”: “./dist/main.js” ./main/main.d.ts

Se estiver ausente, “main” é usado

Package.json Localização padrão do .d.ts
Sem campo “main” index.d.ts
“main”:“index.js” index.d.ts
“main”:“./dist/index.js” ./dist/index.d.ts

Dicas

Se você gostaria de escrever testes para seus arquivos .d.ts, tente tsd.

The TypeScript docs are an open source project. Help us improve these pages by sending a Pull Request

Contributors to this page:
Ccodingsh  (6)
OTOrta Therox  (5)
MUMasato Urai  (1)
Lluk3skyw4lker  (1)

Last updated: 26 de jan. de 2025