使用TypeScript和Node进行热重载

4
有很多文章介绍如何使用nodemon 或者 ts-node-dev 来自动重新启动TypeScript服务器以响应文件更改,但在我的大型TypeScript项目中,整个服务器的重启变得非常缓慢,因为启动时间可能需要数十秒钟(感谢typeorm)。
前端开发已经被诸如create-react-appnextjs等模板主宰,它们提供了热重载功能,甚至无需刷新页面,从而使前端更改的反馈速度非常快。
那么在Node API上有没有类似的东西呢?特别是当源文件是TypeScript而不是JS时。我应该使用tsc --watch然后在编译完成后使require.cache 失效吗?

2
请查看这个库。 - Eldar
你尝试过使用concurrently同时运行tsc-w和nodemon吗? - MBB
@MBB 我特别想知道如何在文件更改时不重新加载整个节点服务器,看看我的问题。 - osdiab
@Eldar 我会试一下,谢谢! - osdiab
1个回答

0

我们使用

/* eslint-env node */

import path from 'path';

import {
  disposeOnReload,
  enableHotReload,
  getReloadCount,
  hotClass,
  hotRequire,
  hotRequireExportedFn,
  registerUpdateReconciler
} from '@hediet/node-reload';
import { IStart, Logger } from './interfaces';
import { initNextJs } from './modules/application/initNextJs';
import { Globals } from './global';

const index = path.join(__dirname, '../client/index.html');

enableHotReload({ entryModule: module, loggingEnabled: false });
registerUpdateReconciler(module);

Logger.log('[ADMIN] Globals.init()');
Globals.init();

@hotClass(module)
class Loader {
  private v1 = 1; // for reload

  static start(info: IStart) {
    return new Promise<void>((done) =>
      hotRequire<typeof import('./server')>(module, './server', (server) => {
        Logger.log('[ADMIN] server.start()');
        server
          .start(info)
          .then(() => {
            done();
          })
          .catch((error) => {
            Logger.error('[ADMIN] Error starting!', { error });
            process.exit(1);
          });
        return {
          dispose: () => {
            Logger.log('[ADMIN] server.stop()');
            server.stop();
          }
        };
      })
    );
  }
}

let startInfo: IStart;
hotRequireExportedFn(module, Loader, { hasFnChanged: 'useSource' }, (loader) => {
  const reloadCount = getReloadCount(module);
  if (reloadCount === 0) {
    Logger.log('[ADMIN] initNextJs');
    const nextApp = initNextJs(true);
    console.time('************************************************** Prepared Next');
    const preparing = nextApp.prepare().then(() => {
      console.timeEnd('************************************************** Prepared Next');
    });
    startInfo = { nextApp, index, preparing };
  }
  setTimeout(() => loader.start(startInfo), 0);
  return { dispose: () => console.log('loader.dispose()') };
});```

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接