刚刚进入 typescript 的世界,并尝试使用 webpack ts-loader 和 babel-loader 将 typescript 编译并转换为 ES5。 但后来我看到 tsc 中有一个可以针对“ES5”的编译器选项,我就想“那我用 babel-loader 来做什么?”
所以我的问题是:
- 当 typescript 编译器定位目标时,内部发生了什么 ES5?
- 我可以单独使用 ts-loader 和 tsconfig 目标选项来实现我的目标吗?
- 如果是这样,哪种方式更好? (ts-loader 到 ES6,然后 babel-loader 到 ES5,或者目标选项设置为 ES5 的 ts-loader)
- 在这两种情况下,tree-shaking(webpack2 功能)会发生什么?
最佳答案
What is happening internally when the typescript compiler targets ES5?
获取 TS/ES 代码并将其转换为 ES5(就像 babel 一样)。
Can I use ts-loader alone with tsconfig target option to achieve my goal?
是的。这就是我所做的。
If so, which way is better?
有偏见的观点:https://medium.com/@basarat/typescript-won-a4e0dfde4b08
What happens with tree-shaking(webpack2 feature) in both cases?
同样的事情。未使用的导出将被删除。
关于typescript - 编译 TypeScript,目标设置为 'ES3' 或 'ES5' 内部,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43842097/