配置@rollup/plugi-commonjs插件处理混合模块

基础环境

rollup ^3.0.0

rollup的treeshake

测试包为lodash-es。

rollup的treeshake默认是开启的。

测试:将rollup的treeshake关闭

treeshake:false,重新打包后的文件大小为504KB

treeshake:true,重新打包后的文件大小为6KB

rollup插件rollup-plugin-delete,在bundling之前删除指定文件或文件夹

rollup插件rollup-plugin-commonjs

报错:RollupError: "default" is not exported by "node_modules/lodsh/isPlainObject.js"

使用@rollup/plugin-commonjs替换rollup-plugin-commonjs

报错: RollupError: "TreeNode" is not exported by "node_modules/ant-design-vue/es/vc-tree/index.js"。

解决方案:

使用@rollup/plugin-commonjs替换rollup-plugin-commonjs

使用@rollup/plugin-node-resolve替换rollup-plugin-node-resolve

参考:https:/rollupjs.org/troubleshooting/#error-name-is-not-exported-by-module

@rollup/plugi-commonjs插件配置如下:

js 复制代码
const commonjs = require('@rollup/plugi-commonjs')

plugins: [
    commonjs({
        include: ['node_modules/**'],
        exclude: ['node_modules/lodash-es', 'node_modules/antd/**']
    })
]

一个esm文件中使用了require,导致require的文件未被引入。

修改@rollup/plugi-commonjs插件配置如下

js 复制代码
const commonjs = require('@rollup/plugi-commonjs')

plugins: [
    commonjs({
        include: ['node_modules/**'],
        exclude: ['node_modules/lodash-es', 'node_modules/antd/**'],
        transformMixedEsModules: true //  混合模块转换
    })
]

transformMixedEsModules

类型:布尔

默认值:false

指示插件是否启用混合模块转换。这在包含ES导入语句和CommonJS require表达式的模块混合的场景中很有用。如果require调用应转换为混合模块中的导入,则设置为true,如果require表达式应在转换后继续存在,则设置成false。如果代码包含环境检测,或者您正在为对ElectronJS等require调用进行特殊处理的环境进行编码,则后者可能很重要。另请参见"忽略"选项。

相关推荐
IT_陈寒29 分钟前
Redis缓存击穿把我整不会了,原来还有这手操作
前端·人工智能·后端
idcu1 小时前
深入 Lyt.js 组件系统:L2 渲染引擎层的核心
前端·typescript
这是程序猿1 小时前
Spring Boot自动配置详解
java·大数据·前端
文心快码BaiduComate1 小时前
干货|Comate Harness Engineering工程实践指南
前端·后端·程序员
还有多久拿退休金1 小时前
一张栈的图,治好你面试答不出 script 阻塞的病
前端·javascript
光辉GuangHui1 小时前
Agent Skill 也需要测试:如何搭建 Skill 评估框架
前端·后端·llm
To_OC1 小时前
我终于搞懂 Claude Code 核心逻辑!90%的人都用错了模式
前端·ai编程
蓝宝石的傻话1 小时前
Headless浏览器的隐形陷阱:为什么你的AI自动化工具抓不到页面早期错误?
前端
irving同学462381 小时前
Node 后端实战:JWT 认证与生产级错误处理
前端·后端
莽夫搞战术2 小时前
【Google Stitch】AI原生画布重新定义设计,让想法变成可交互界面
前端·人工智能·ui