Lon*_*fPR 8 node.js yarnpkg yarn-workspaces yarn-v2
我正在测试设置 yarn 2 工作区。我想我已经按照我应该的方式完成了它,但是当我yarn install从根目录运行时,它不会安装任何模块,也不会按预期创建依赖项的符号链接。我有以下文件夹结构
root/
package-a/
package-b/
Run Code Online (Sandbox Code Playgroud)
每个都包含一个 package.json,每个包文件夹都包含一个 index.js。这是 package.json 文件
根:
{
"name": "yarn-workspaces-poc",
"version": "1.0.0",
"license": "MIT",
"private": true,
"workspaces": [
"package-a/",
"package-b/"
]
}
Run Code Online (Sandbox Code Playgroud)
包-a:
{
"name": "package-a",
"version": "1.0.0",
"type": "module",
"dependencies": {
"cross-env": "5.0.5",
"package-b": "workspace:*"
}
}
Run Code Online (Sandbox Code Playgroud)
包-b:
{
"name": "package-b",
"version": "1.0.0",
"type": "module",
"main": "index.js",
"dependencies": {
"cross-env": "5.0.5"
}
}
Run Code Online (Sandbox Code Playgroud)
这是js文件
包-a/index.js
import test from "package-b";
console.log('testing');
console.log(test());
Run Code Online (Sandbox Code Playgroud)
包-b/index.js
export default function b() {
console.log("From b. You made it!");
}
Run Code Online (Sandbox Code Playgroud)
预期的行为是,当我yarn install从根运行时,将在那里创建 node_modules 文件夹。它应该包含 cross-env 包以及一个符号链接到 package-b 的文件夹。然而,没有任何东西被创建。这是命令的输出:
? YN0000: ? Resolution step
? YN0000: ? Completed
? YN0000: ? Fetch step
? YN0000: ? Completed
? YN0000: ? Link step
? YN0000: ? Completed
? YN0000: Done in 0s 96ms
Run Code Online (Sandbox Code Playgroud)
编辑:
另外,如果我只是运行 package-a 来测试它,结果是:
internal/process/esm_loader.js:74
internalBinding('errors').triggerUncaughtException(
^
Error [ERR_MODULE_NOT_FOUND]: Cannot find package 'package-b' imported from /root/package-a/index.js
Did you mean to import package-b/index.js?
at packageResolve (internal/modules/esm/resolve.js:655:9)
at moduleResolve (internal/modules/esm/resolve.js:696:18)
at Loader.defaultResolve [as _resolve] (internal/modules/esm/resolve.js:810:11)
at Loader.resolve (internal/modules/esm/loader.js:86:40)
at Loader.getModuleJob (internal/modules/esm/loader.js:230:28)
at ModuleWrap.<anonymous> (internal/modules/esm/module_job.js:56:40)
at link (internal/modules/esm/module_job.js:55:36) {
code: 'ERR_MODULE_NOT_FOUND'
}
Run Code Online (Sandbox Code Playgroud)
.yarnrc.yml在你的 monorepo 的根部创建一个,
向其中添加以下属性:
nodeLinker: node-modules
Run Code Online (Sandbox Code Playgroud)
也许 Yarn 2 最显着的变化是 PnP 系统。告别node_modules
这是默认行为,除非您指定“旧版”node-modules链接器
记录在这里
对于单独部署包,有时可以防止提升node_modules到根目录。
你可以加
nmHoistingLimits: workspaces
Run Code Online (Sandbox Code Playgroud)
确保.yarnc.yml每个包都直接在包级别安装其依赖项。
noHoist: [*/**]这比纱线 1 中的旧版本更加稳健。
小智 2
我有类似的问题。事实证明,新版本的Yarn没有使用node_modules:
https://yarnpkg.com/getting-started/migration#switching-to-plugnplay
https://yarnpkg.com/getting-started/migration#final-notes
这确实令人困惑,因为它与工作区的文档不一致......它描述了您(和我)期望的结果: https: //yarnpkg.com/features/workspaces
运行“yarn install”后,您可以按照之前的方式启动服务器,但要在前面加上“yarnworkspaceWORKSPACENAME”。
所以如果你通常会这样开始:
rootfolder$ cd package-b
package-b$ node index.js
Run Code Online (Sandbox Code Playgroud)
您现在可以从根文件夹运行它:
rootfolder$ yarn workspace package-b node index.js
Run Code Online (Sandbox Code Playgroud)
您可能还需要为 IDE 等设置一些其他内容。这里有大量信息: https: //yarnpkg.com/getting-started/migration#switching-to-plugnplay
| 归档时间: |
|
| 查看次数: |
591 次 |
| 最近记录: |