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

相关推荐
程序员黑豆8 分钟前
AI全栈开发之Java:怎么配置Java环境变量
前端·后端·ai编程
xiaofeichaichai30 分钟前
React Hooks
前端·javascript·react.js
问心无愧05131 小时前
ctf show web入门110
前端·笔记
拉拉肥_King1 小时前
Vue 3 主题切换深度解析:从炫酷动画到零闪烁方案
前端·vue.js
excel1 小时前
为什么 Pinia + localForage 持久化后,页面初始化拿不到数据?
前端
雨雨雨雨雨别下啦1 小时前
vant介绍
前端
小小小小宇1 小时前
大模型失忆问题探讨
前端
wordbaby1 小时前
rn-cross-calendar:一个兼容 React 18/19、RN/RNOH 的跨平台日历组件
前端·react native·harmonyos
weixin_523185321 小时前
Collections.unmodifiableMap详解:真的不可修改吗?
java·linux·前端
江米小枣tonylua1 小时前
关掉 VSCode:在 NeoVim12 上配置 Claude Code
前端·程序员