rollup-plugin-copy在 vite@5.0.11中不生效解决办法

在打包的时候, 我们需要将一些文件copy到 打包后的目录.

使用 vite 可以很方便的复用 rollup的插件生态, 但是发现一个小小的问题,需要我们自己注意一下

环境说明

sql 复制代码
node: 20.10.0
rollup-plugin-copy  3.5.0
vite  5.0.11

截止到 2024-01-09 ,插件均为最新版本

安装

shell 复制代码
pnpm add rollup-plugin-copy vite -D

使用

不生效的写法

js 复制代码
import { defineConfig } from 'vite'
import copy from 'rollup-plugin-copy'

export default defineConfig({
    build: {
        outDir: 'lib',
        lib: {
          entry: resolve('./src/index.js'),
          name: 'test-ui',
          fileName: 'ems'
        },
    }),
    plugins: [
        ...其他插件
        copy({
          targets: [
            { src: './package.json', dest: './lib' }
          ]
        }),

    ]
})

发现在 输出目录 lib下面使用没有 要搬运的文件 package.json。

可能是 rollup-plugin-copy 的版本与 rollup 存在差异, 主要应该是 rollup hooks 的差异, 现在,我们将执行时机改为 由 buildEnd 改为 closeBundle

buildEndrollup-plugin-copy 使用的默认的 hook

  • buildEnd 执行时机:在 Rollup 完成产物但尚未调用 generatewrite 之前调用;也可以返回一个 Promise。如果在构建过程中发生错误,则将其传递给此钩子。

  • closeBundle: 可用于清理可能正在运行的任何外部服务。Rollup 的 CLI 将确保在每次运行后调用此钩子,但是 JavaScript API 的用户有责任在生成产物后手动调用 bundle.close()。因此,任何依赖此功能的插件都应在其文档中仔细提到这一点 - 需要手动维护资源的释放

修改为:

js 复制代码
 plugins: [
     ...其他插件
    copy({
      // 显示日志
      verbose: true,
      hook: 'closeBundle',
      targets: [
        { src: './package.json', dest: './lib' }
      ]
    }),
  ]
相关推荐
叁两12 分钟前
用opencode打造全自动公众号写作流水线,AI 代笔太香了!
前端·人工智能·agent
golang学习记17 分钟前
GitLens 十大神技:彻底改变你在 VS Code 中的 Git 工作流
前端·后端·visual studio code
SuperEugene18 分钟前
后台权限与菜单渲染:基于路由和后端返回的几种实现方式
前端·javascript·vue.js
兆子龙20 分钟前
WebSocket 入门:是什么、有什么用、脚本能帮你做什么
前端·架构
是一碗螺丝粉25 分钟前
LangChain 链(Chains)完全指南:从线性流程到智能路由
前端·langchain·aigc
月弦笙音30 分钟前
【浏览器】这几点必须懂
前端
青青家的小灰灰31 分钟前
迈向全栈新时代:SSR/SSG 原理、Next.js 架构与 React Server Components (RSC) 实战
前端·javascript·react.js
SuperEugene31 分钟前
弹窗与抽屉组件封装:如何做一个全局可控的 Dialog 服务
前端·javascript·vue.js
UrbanJazzerati32 分钟前
事件传播机制详解(附直观比喻和代码示例)
前端
青青家的小灰灰32 分钟前
透视 React 内核:Diff 算法、合成事件与并发特性的深度解析
前端·javascript·react.js