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

标签 reactjs typescript npm

我有一个 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/

相关文章:

reactjs - 通过高阶组件注入(inject) props 会导致编译器错误

reactjs - Eslint错误: Do not nest ternary expressions

javascript - 如何在 Gitlab CI 中设置环境变量并使其在本地可测试

angularjs - 我应该使用 typescript 吗?或者我可以只使用 ES6?

angular - 在 TypeScript.2.7 中找不到名称 'TextDecoder'

Angular XLSX 库,导出对象数组

node.js - React js 应用-高危漏洞-immer

npm 安装不起作用 | npm 错误!路径 | npm 错误!代码 | npm 错误!错误 | npm 错误!系统调用 | npm 错误!恩恩特

node.js - 创建项目后 Gatsby 开发不工作

javascript - 在字符串之间使用标签 <mark>