gpt4 book ai didi

reactjs - 我如何 `npm link` 与对等依赖项的 typescript 依赖项?

转载 作者:搜寻专家 更新时间:2023-10-30 20:32:30 24 4
gpt4 key购买 nike

我有一个 React/Redux typescript 项目 A。我的团队决定将一些 React 组件和 Redux 代码拆分到一个 NPM 模块中,因此我创建了另一个 React/Redux TS 项目 B。

最初,当我尝试从 A 安装 B 时,由于类型重新声明而出现错误,因为 A 和 B 都依赖于相同的类型声明文件(react、redux 等)。所以我将 B 的所有 @types 依赖项都移动为对等依赖项。这使我能够从 A 正确安装 B。

但是,出于开发目的,我想从 A npm link 到 B,这样我就不必经常重新编译和重新安装 B。但是因为 npm link 创建一个符号链接(symbolic link),它指向整个 B 项目,包括我需要避免的类型定义。

有谁知道如何解决这个难题?

最佳答案

这个问题与 typescript 没有特别的关系,而是一个关于如何将两个 javascript 包链接在一起并防止库多次加载的一般问题。如何解决这个问题的一个重要因素取决于您使用的构建/ bundler 。我觉得这个stackoverflow answer如果您只关心重复数据删除 react ,那就太好了。

下面是一个使用webpack解决的例子。

首先要确保您的子包中的任何共享依赖项都是 devDependencies 和 peerDependencies,并且您的父包将它们设置为所需的依赖项和 devDependencies。

A - package.json

{
"dependencies": {
"B": "1.0.0",
"react": "x.x.x",
},
"devDependencies": {
"@types/react": "x.x.x"
}
}

B - package.json

{
"version": "1.0.0",
"peerDependencies": {
"@types/react": "x.x.x",
"react": "x.x.x"
},
"devDependencies": {
"@types/react": "x.x.x",
"react": "x.x.x"
}
}

如果你从包 A 运行 webpack,你需要确保在仅适用于包 A 的 node_modules 时解析 node_modules。

const path = require('path')
module.exports = {
// rest of your webpack condig...
resolve: {
modules: [path.resolve(__dirname, 'node_modules'), 'node_modules']
}
}

这也是另一个使用 react-app-rewired 做同样事情的解决方案

const path = require('path')
module.exports = function override(config) {
config.resolve = Object.assign({}, config.resolve, {
modules: [path.resolve(__dirname, 'node_modules'), ...config.resolve.modules]
})

return config
}

关于reactjs - 我如何 `npm link` 与对等依赖项的 typescript 依赖项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43852717/

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