gpt4 book ai didi

node.js - 如何在 browserify 中填充 npm 包依赖项?

转载 作者:太空宇宙 更新时间:2023-11-04 02:15:16 25 4
gpt4 key购买 nike

所以我有一个 React 项目,其中我实际上使用 React-lite 进行部署,因为占用空间小得多。我想使用react-nouislider ,但在它的 package.json 中,我发现了这个:

"peerDependencies": {
"react": "^0.14.0"
}

这意味着每当我需要react-nouislider时,它都会引入React而不是react-lite。如何从我的顶级 package.json 中填充 npm 包的依赖项?

这就是我如何调整react-lite:

"browser": {
"react": "react-lite"
}

我尝试了这个,但没有成功:

"browserify-shim":{
"react-nouislider": {
"depends": "react-lite"
}
}

如何填充包本身的依赖关系?

最佳答案

Browserify Shim 的口号是:

Makes CommonJS incompatible files browserifyable.

您的问题是 react-lite 已经与 CommonJS 兼容。对于任何 CommonJS 兼容文件,Browserify 将在 Browserify Shim 介入之前根据需要自动添加其依赖项peerDependency

我建议您将 react-nouislider 包中的 peerDependency 条目更改为适当版本的 react-lite 并删除上面的 Browserify Shim 配置,因为不再需要它。执行此操作时,请务必在 react-nouislider 包中运行任何测试,以确保它仍然适用于 react-lite 而不是 React。实现此目的的一个好方法是将 react-nouislider fork 到您自己的存储库,在那里进行更改,然后从 package.json 中的该存储库中提取。

关于node.js - 如何在 browserify 中填充 npm 包依赖项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36055865/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com