React react-app-env.d.ts是 TypeScript 的全局类型声明文件,它的作用

src/react-app-env.d.ts 是 TypeScript 的全局类型声明文件,在这个项目中承担以下几个作用:

  1. 引入 React 脚手架内置类型
clike 复制代码
/// <reference types="node" />
/// <reference types="react" />
/// <reference types="react-dom" />`在这里插入代码片`

三条三斜线指令,让 TypeScript 自动加载 Node.js、React、ReactDOM 的类型定义,无需在每个文件里手动 import。

  1. 扩展 process.env 的类型
dart 复制代码
declare namespace NodeJS {
  interface ProcessEnv { ... }
}

定义了项目自定义的环境变量(如 REACT_APP_Version_Code),使访问 process.env.REACT_APP_Version_Code 时有类型提示和检查。

  1. 声明静态资源模块类型
dart 复制代码
declare module '*.png' { ... }
declare module '*.svg' { ... }

告诉 TypeScript:import logo from './logo.png' 这类导入是合法的,并且知道导出的是 string 类型。

  1. 声明样式文件模块类型
dart 复制代码
declare module '*.less' {}           // 普通 less,副作用导入
declare module '*.css' {}            // 普通 css,副作用导入
declare module '*.module.less' { ... } // CSS Modules,有具名导出
declare module '*.module.css' { ... }  // CSS Modules,有具名导出

区别:*.module.less 有 export default classes 是因为 CSS Modules 会导出一个类名映射对象;而普通 *.less 只是副作用导入(注入样式),不需要导出值,所以声明为空 {}。

  1. 扩展 Window 全局对象
dart 复制代码
interface Window {
  hubConnection: HubConnection;
}

让 window.hubConnection 访问时不报 TS 错误,对应 App.tsx 里直接挂载 SignalR 连接对象到 window 上的做法。

相关推荐
暗不需求几秒前
深入理解 LangChain:AI 应用开发框架的工程化实践
前端·langchain
用户0595401744621 分钟前
把 Redis 持久化测试从 800 行 Shell 换成 30 行 pytest,排错效率翻了 10 倍
前端·css
GISer_Jing26 分钟前
AI全栈工程师知识体系全景:从前后端核心架构到落地项目全拆解
前端·人工智能·后端·ai编程
Wect31 分钟前
深度剖析浏览器跨域问题
前端·面试·浏览器
陈随易1 小时前
bun将会支持Bun.image,你怎么看?
前端·后端·程序员
jingqingdai31 小时前
别用正则格式化 HTML!我用 DOM 遍历实现零风险本地格式化,老项目重构效率直接拉满
前端·重构·html
木斯佳1 小时前
前端八股文面经大全:腾讯前端实习二、三OC面(2026-04-27)·面经深度解析
前端·状态模式
Python私教1 小时前
如意Agent日志系统重构:从 print() 大海捞针到结构化可观测性栈
java·前端·重构
We་ct2 小时前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划