风行视频最新版
56.29MB · 2025-11-08
根据文档,配置完毕后,本地运行项目一切正常,但到打包构建时却出现了一下问题。
Could not resolve "./lib/globalThis-analytics-helper"
from "node_modules/@segment/analytics-next/dist/pkg/index.js"
一开始没有发现问题所在,就去 node_modules/@segment/analytics-next/dist/pkg/index.js 文件里面查找,是否引用了./lib/globalThis-analytics-helper,只发现了
export { getGlobalAnalytics } from './lib/global-analytics-helper';
这个的引用,没有 globalThis-analytics-helper为什么global会变成globalThis内,我就把 vite.config.ts 中的define: { global: 'globalThis' }配置注释,再次打包竟然成功了,这里我就发现了是这里的问题导致的,后面就改成了
optimizeDeps: {
esbuildOptions: {
// Node.js global to browser globalThis
define: {
global: "globalThis",
},
// Enable esbuild polyfill plugins
plugins: [],
},
},
打包就成功了,而且本地也可以正常运行了。
define.global 的作用:
Vite在构建阶段(包括dev和build)会 把项目中所有出现的global替换成globalThis。optimizeDeps.esbuildOptions.define 的区别:
Node.js库的global兼容性问题。 define: { global: 'globalThis'},配置后,导致和@segment/analytics-next内的global冲突,在打包时把@segment/analytics-next路径中global替换成了globalThis导致路径解析时,找不到路径而失败。