typescript - 带有 Expo 和 Typescript 的 NPM 工作区
问题描述
我正在尝试在 Typescript Expo 项目中使用 NPM 7 工作区。现在我想保持正常的 Expo 结构(使用根App.tsx
文件),但我想隔离工作区中的某些部分代码。
我在工作区中编译 TS 代码时遇到问题。我尝试了很多方法来配置 TS 和/或 Webpack 配置,但没有成功。所以这里是重现它的最小文件结构:
package.json
tsconfig.json
App.tsx
/packages
/core
index.ts
package.json
这是根的相关部分./package.json
{
"main": "node_modules/expo/AppEntry.js",
"workspaces": [
"packages/*"
],
"scripts": {...},
"dependencies": {...},
"devDependencies": {...},
"private": true
}
./tsconfig.json
是最低限度的
{
"extends": "expo/tsconfig.base",
"compilerOptions": {
"strict": true
}
}
也./packages/core/package.json
很简单
{
"name": "core",
"private": true
}
并且简单地为这个例子./packages/core/index.ts
导出一个函数log()
export function log(s: string) {
console.log(s)
}
最后, in ./App.tsx
, 只是导入函数并尝试调用它
import { log } from 'core'
log('hello')
//...
它不编译
当我尝试为网络构建(expo build:web
例如)时,出现以下错误
✖ Expo Webpack
Compiled with some errors in 1.62s
Failed to compile.
[path]/node_modules/core/index.ts 1:21
Module parse failed: Unexpected token (1:21)
You may need an appropriate loader to handle this file type, currently no loaders are configured to process this file. See https://webpack.js.org/concepts#loaders
> export function log(s: string) {
| console.log(s)
| }
我并不感到惊讶,因为该/node_modules
目录被自愿排除在外。
所以我的问题是我需要做什么才能编译工作区代码?我希望它可以即时工作(即:未预编译),就像它是我项目中的一些常规文件一样。它完全可行吗?
一些失败的修复尝试
我主要尝试调整 tsconfig 以使其正常工作(尽管我想知道它是否会改变任何东西)
#1
我尝试添加"include": ["./node_modules/core"],
. 它没有效果(同样的错误)。./tsconfig.json
#2
我尝试/packages/core/tsconfig.json
使用复合选项创建以下内容:
{
"extends": "expo/tsconfig.base",
"compilerOptions": {
"strict": true,
"composite": true
}
}
并在根目录中引用它tsconfig.json
{
"extends": "expo/tsconfig.base",
"compilerOptions": {
"strict": true
},
"references": [{ "path": "./node_modules/core" }]
// or even with:
"references": [{ "path": "./packages/core" }]
}
它没有效果(同样的错误)。
非常感谢
解决方案
我想出了一个我不太满意的解决方案,但至少它是有效的。这实际上很简单,我只是配置了 Webpack 来编译我的packages/*
(作为node_modules
.
所以首先我安装了:
$ npm i -D ts-loader@8 webpack@4.430
版本在这里很重要,要与 Expo 41 使用的 webpack 版本保持一致。
我还将我的包名 (in /packages/core/package.json
) 重命名为类似@workspace/core
这样的名称,以便我所有的自定义包都在node_modules/@workspace
目录中。
它还将使我们的配置更简单。
运行$ expo customize:web
是自定义 webpack 配置所必需的。它会产生一个webpack.config.js
.
它可以定制如下:
const createExpoWebpackConfigAsync = require('@expo/webpack-config')
module.exports = async function (env, argv) {
const config = await createExpoWebpackConfigAsync(env, argv)
config.module.rules = [
{
// this is why I renamed my packages with the @workspaces prefix.
test: /node_modules\/@workspaces\/(.*)\.ts$/,
use: [
{
loader: 'ts-loader',
// force ts-loader to compile in node_modules
options: { allowTsInNodeModules: true },
},
],
},
...config.module.rules,
]
return config
}
如果有更清洁的解决方案,我不会感到惊讶。但现在我会坚持下去
推荐阅读
- python - 如何根据另一列中的值是否包含在另一个数据框的特定列中来设置一个数据框的列值
- python - python将classB中的方法作为参数传递给classA,然后从传递的classB方法中调用classA中的方法
- laravel - laravel 5.4 HTTP ERROR 500 无法处理此请求
- keras - ONNX 到 Keras 的转换
- flutter - 在键盘事件上禁用小部件移动
- html - 如何使 5 行引导网格占据整个窗口?
- react-native - 如何在来自映射函数的组件之间添加空间?
- amazon-web-services - 将 API Gateway websocket 直接映射到无服务器中的 kinesis 流
- mysql - 当我使用另一个表的 SUM 时无法解析列
- c++ - 实例化新类时未调用方法