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 上的做法。

相关推荐
古夕17 分钟前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之20 分钟前
页面白屏卡住排查方法
前端·javascript
用户5936087414020 分钟前
Playwright 黑魔法:用 ClipboardEvent 绕过 React 富文本编辑器
前端
Ruihong24 分钟前
Vue withDefaults 转 React:VuReact 怎么处理?
vue.js·react.js·面试
石山岭1 小时前
自己动手写了一个 Android 虚拟定位 App:GPSSimulate 技术实
android·前端
犇驫聊AI1 小时前
Chrome DevTools MCP + Claude Code 自定义skills生成接口代码生成器
前端·javascript
kyriewen1 小时前
别再这样写 async/await 了:我在 Code Review 中见过最多的 8 个错误
前端·javascript·面试
hoLzwEge2 小时前
node-linker VS shamefully-hoist
前端·前端框架
袋鱼不重2 小时前
解决 Web 端图片预览与下载颜色不一致的一种工程方案
前端·后端
风止何安啊2 小时前
教你用 JS + AI 实现简单的爬虫,零门槛爬取网页信息
前端