![](/img/trans.png)
[英]How to run nodemon + ts-node + typescript altogether without having to install ts-node or npx globally?
[英]Run glob command in TypeScript (TS-Node)
幾個月前,我問過如何將 glob 輸入到 Node 模式中。 我想在RITEway中運行測試,解決方案是使用riteway
而不是node
運行命令。
"test": "NODE_ENV=test riteway -r @babel/register 'src/**/*.test.js'",
現在我將項目轉換為 TypeScript。 運行上面的命令(將.js
更改為.ts
之后),會引發以下錯誤:
$ NODE_ENV=test riteway -r @babel/register 'src/tests/**/*.test.ts' | tap-nirvana
/Users/user/my-proj/src/tests/fn.test.ts:1
import { describe } from 'riteway';
^^^^^^
SyntaxError: Cannot use import statement outside a module
at wrapSafe (internal/modules/cjs/loader.js:979:16)
at Module._compile (internal/modules/cjs/loader.js:1027:27)
at Module._extensions..js (internal/modules/cjs/loader.js:1092:10)
at Object.newLoader [as .js] (/Users/user/my-proj/node_modules/pirates/lib/index.js:104:7)
at Module.load (internal/modules/cjs/loader.js:928:32)
at Function.Module._load (internal/modules/cjs/loader.js:769:14)
at Module.require (internal/modules/cjs/loader.js:952:19)
at require (internal/modules/cjs/helpers.js:88:18)
at /Users/user/my-proj/node_modules/riteway/bin/riteway:54:5
at Array.forEach (<anonymous>)
谷歌搜索后,我想我必須使用ts-node
,但該命令與運行node
有相同的問題。
yarn run v1.22.10
$ NODE_ENV=test ts-node -r @babel/register 'src/tests/**/*.test.ts' | tap-nirvana
Error: Cannot find module '/Users/user/my-project/src/tests/**/*.test.ts'
如何將命令提供給 RITEway,但使其與 TypeScript 一起使用?
{
"compilerOptions": {
"allowJs": true,
"baseUrl": "./src",
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"isolatedModules": true,
"jsx": "preserve",
"lib": ["dom", "dom.iterable", "esnext"],
"module": "esnext",
"moduleResolution": "node",
"noEmit": true,
"resolveJsonModule": true,
"skipLibCheck": true,
"strict": true,
"target": "es5"
},
"exclude": ["node_modules"],
"include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"]
}
您可以通過在riteway
命令中注冊ts-node/register/transpile-only
來運行已編譯的 typescript:
"test": "NODE_ENV=test riteway -r ts-node/register/transpile-only 'src/**/*.test.ts'",
還要確保tsconfig
中的module
選項設置為commonjs
:
{
"compilerOptions": {
"allowJs": true,
"baseUrl": "./src",
"esModuleInterop": true,
"forceConsistentCasingInFileNames": true,
"isolatedModules": true,
"jsx": "preserve",
"lib": [
"dom",
"dom.iterable",
"esnext"
],
"module": "commonjs",
"moduleResolution": "node",
"noEmit": true,
"resolveJsonModule": true,
"skipLibCheck": true,
"strict": true,
"target": "es6"
},
"exclude": [
"node_modules"
],
"include": [
"next-env.d.ts",
"**/*.ts",
"**/*.tsx"
]
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.