记rspack想提issuse,提太慢白嫖不上了

昨天下午在研究了rspack, 在使用cli创建项目时,偶然发现一个bug, 会导致quick Start的项目启动时候会导致ts类型错误 本来打算提个issue,Pr,偷懒一下想等第二天,结果提一半被修好了

bash 复制代码
pnpm create rspack
# 项目名称随意
# 选择react
# 选择ts
# 随意
cd 进项目

pnpm i
pnpm dev
javascript 复制代码
// rspack.config.ts
import * as RefreshPlugin from "@rspack/plugin-react-refresh"

...

plugins: [
		new rspack.HtmlRspackPlugin({
			template: "./index.html"
		}),
		
// 报错的一行
		isDev ? new RefreshPlugin() : null
	].filter(Boolean),

今天早上刚写了issue一半,发现复现不了,代码还是一样的,原来刚好被修了

检查一下发现是 @rspack/plugin-react-refresh 这个库的原因

json 复制代码
// package.json 
"@rspack/plugin-react-refresh": "^1.2.0",

从 有错误的版本 1.3.0 更新到 1.3.1

github.com/rspack-cont...

可以发现1.3.0进行了这部分修改,然后1.3.1又改回来了

再切入一段报错代码具体情况

javascript 复制代码
// rspack.config.ts
import * as RefreshPlugin from "@rspack/plugin-react-refresh"

...

plugins: [
		new rspack.HtmlRspackPlugin({
			template: "./index.html"
		}),
		
// 报错的一行
		isDev ? new RefreshPlugin() : null
	].filter(Boolean),

想一下我们的es导入和导出方式

javascript 复制代码
// esm 命名空间导入
import * as RefreshPlugin from "@rspack/plugin-react-refresh"
// 或 命名导入
import { RefreshPlugin } from "@rspack/plugin-react-refresh"

// cjs
const RefreshPlugin = require("@rspack/plugin-react-refresh")
arduino 复制代码
// ts 特有语法,兼容CommonJs/AMD
export = ReactRefreshRspackPlugin

// 默认导出 可以使用任意名称导入
export default ReactRefreshRspackPlugin

// 命名导出
export { ReactRefreshRspackPlugin }

这里普及一下 ts语法 export = (,对应的导入方式如下

javascript 复制代码
import xxx = require('模块路径');
import * as xxx from '模块路径';

// ts配置esModuleInterop才可使用
import xxx from '模块路径';  // 需要 esModuleInterop: true

所以 1.3.0 的 export { ReactRefreshRspackPlugin } 是具名导出

import * as RefreshPlugin from "@rspack/plugin-react-refresh" 会导致所有导出内容放在 RefreshPlugin 对象下,需要通过RefreshPlugin.ReactRefreshRspackPlugin 访问

小螃蟹可爱

相关推荐
清汤饺子8 小时前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
颜酱8 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
爱吃的小肥羊10 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒11 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿12 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人12 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥12 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪12 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao12 小时前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_233312 小时前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能