首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何逐步将节点app从javascript迁移到typescript

如何逐步将节点app从javascript迁移到typescript
EN

Stack Overflow用户
提问于 2018-10-14 03:54:37
回答 1查看 598关注 0票数 0

我有一个javascript节点应用程序,它现在非常大,我想切换到typescript来加速开发并更好地维护代码。我使用以下命令安装了带有nodemocha类型的typescript

代码语言:javascript
复制
npm i typescript
npm i @types/node
npm i @types/mocha

我使用一个tsconfig.json文件,如下所示:

代码语言:javascript
复制
{
    "compilerOptions": {
        "target": "es6",
        "module": "commonjs",
        "outDir": "dist",
        "sourceMap": true
    },
    "files": [
        "./node_modules/@types/mocha/index.d.ts",
        "./node_modules/@types/node/index.d.ts"
    ],
    "include": [
        "src/**/*.ts",
    ],
    "exclude": [
        "node_modules"
    ]
}

我在package.json中添加了"tsc": "tsc"脚本,以便使用npm run tsc命令编译代码。

以下是我的项目架构:

代码语言:javascript
复制
- dist // created at compile time
- src
--- server.ts
--- configs
----- config.js
--- // other subdirectories
- package.json
- tsconfig.json

当我编译代码时,它会创建一个dist文件夹,其中只包含编译后的server.ts文件,我将这个文件重命名为.ts。因此,当我使用node dist/server.js启动编译后的应用程序时,所有其他文件都会丢失,并且应用程序会崩溃。

我的问题是:我是否必须将整个应用程序切换到typescript,将每个文件重命名为.ts并更改导入,还是有一种方法可以逐步完成并保留一些javascript文件?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-14 04:22:47

正如Jeff在我的帖子评论中提到的,这里是你如何逐步切换到typescript的方法。基于他提供的链接Migrating from javascript documentation,这里是我如何设法让它工作的。

我将tsconfig.json文件更改为:

代码语言:javascript
复制
{
    "compilerOptions": {
        "allowJs": true, // <-- option to allow js files as input in the ts compiler
        "target": "es6",
        "module": "commonjs",
        "outDir": "./dist",
        "sourceMap": true
    },
    "files": [
        "./node_modules/@types/mocha/index.d.ts",
        "./node_modules/@types/node/index.d.ts"
    ],
    "include": [
        "./src/**/*",
    ],
    "exclude": [
        "node_modules"
    ]
}

我还更改了项目的package.json,以启动应用程序并从编译文件夹(在我的示例中为dist )中运行测试:

代码语言:javascript
复制
...
"scripts": {
    "start": "node ./dist/server.js",
    "test": "tsc && ./node_modules/.bin/mocha --recursive ./dist/test",
    "tsc": "tsc",
},
...
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52796773

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档