typescript中Triple-Slash Directives如何使用

在 TypeScript 中,Triple-Slash Directives(三斜线指令)是包含 XML 标签的单行注释,用于在编译过程中提供指令。它们必须放在文件的最顶部,前面只能有注释或其他三斜线指令。

主要的三斜线指令

1. /// <reference types="..." />

用于声明对某个类型的依赖。

Dart 复制代码
/// <reference types="node" />
/// <reference types="react" />

import * as fs from 'fs'; // 现在可以使用 node 的类型
import * as React from 'react';

2. /// <reference path="..." />

用于声明对另一个文件的依赖。

TypeScript 复制代码
/// <reference path="types.d.ts" />
/// <reference path="../utils/helpers.ts" />

const user: User = { name: "John" }; // User 类型在 types.d.ts 中定义

3. /// <reference lib="..." />

显式包含内置的库文件。

TypeScript 复制代码
/// <reference lib="es2015" />
/// <reference lib="dom" />

// 现在可以使用 ES2015 和 DOM 的 API
const promise = Promise.resolve();
document.getElementById("app");

现代替代方案

虽然三斜线指令仍然有效,但在很多情况下有更好的替代方案:

使用 import 代替 /// <reference>

TypeScript 复制代码
// 旧的写法
/// <reference types="jquery" />

// 现代写法
import * as $ from 'jquery';

在 tsconfig.json 中配置

TypeScript 复制代码
{
  "compilerOptions": {
    "types": ["node", "react"],
    "lib": ["es2015", "dom"]
  }
}
相关推荐
自在极意功。1 小时前
AJAX 深度详解:从基础原理到项目实战
前端·ajax·okhttp
s***4531 小时前
SpringBoot返回文件让前端下载的几种方式
前端·spring boot·后端
海上彼尚1 小时前
[逆向] 1.本地登录爆破
前端·安全
什么时候吃饭1 小时前
vue2、vue3父子组件嵌套生命周期执行顺序
前端·vue.js
2501_940943912 小时前
体系课\ Python Web全栈工程师
开发语言·前端·python
q***06472 小时前
SpringSecurity相关jar包的介绍
android·前端·后端
低保和光头哪个先来2 小时前
场景2:Vue Router 中 query 与 params 的区别
前端·javascript·vue.js·前端框架
q***95222 小时前
SpringMVC 请求参数接收
前端·javascript·算法
|晴 天|2 小时前
Vite 为何能取代 Webpack?新一代构建工具的崛起
前端·webpack·node.js