Microsoft/TypeScript

Move away from Classic module resolution as default for all module kinds

Open

#11,434 建立於 2016年10月6日

在 GitHub 查看
 (8 留言) (10 反應) (0 負責人)TypeScript (48,455 star) (6,726 fork)batch import
CommittedEffort: ModerateHelp WantedSuggestion

描述

TypeScript's original module resolution strategy (the Classic resolution strategy) has some strange behavior that apparently doesn't actually reflect any other resolution strategy. It seems strange that those using non-CommonJS emit targets get this behavior by default.

Classic resolution also causes many disk probes during the walk up the project root - assuming that this strategy does eventually succeed in most cases, it seems like most uses could be subsumed by:

  • Using relative paths.
  • Modifying the baseUrl and paths properties in tsconfig.json.

After discussing with @vladima, we think it is worth considering switching the default resolution strategy for all module targets to Node.

Here's what needs to be done:

  • Investigate existing tsconfig.jsons that target esXXXX` and have no explicit/implied resolution strategy.
  • Determine the downstream effects to a change to defaults
  • Determine if this change outweighs the potential breakage
  • Implement if appropriate

貢獻者指南