This article was first published on the public account “Xiao Li’s Front-end cabin”, welcome to follow ~
In modern Web applications, source code often needs to be compiled and packaged, dead code deleted, code conversion and other processing in order to make the code can operate in the production environment with high performance.
Babel and Typescript are two of the most common compilers available today, and this article discusses the differences between them to help you choose the best tool for your project.
introduce
Babel
Babel is a JS compiler that converts modern ES6+ syntax and features into backwards-compatible syntax to run in current and older browsers and other environments. Have syntax conversion, Polyfill, source conversion and other capabilities,
TypeScript
TS is one of the most commonly used programming languages at present. It is JS with a type system, which can help avoid some errors in development.
TS has its own compiler that can convert.ts files into.js files and run them in a browser, Node.js, or any other environment that can run JS.
Both comparisons
Although they are both compilers, there are some differences.
Babel can’t do type checking
TS does type checking at compile time, whereas Babel does not, so Babel compiles faster.
You can use TSC — noEmit for separate TS type checking
TS cannot automatically polyfill
Babel and TS are just compilers, and it’s core-JS that really polyfills the API.
Core-js is a set of modular JS standard libraries that provide the core implementation of Polyfill.
Babel’s @babel/ Polyfill module includes core-JS and Regenerator-Runtime to simulate the full ES2015+ environment. So Babel comes with polyfill.
Regenerator-runtime is a runtime dependency of generator and async/await.
TS can only be compiled to the ECMAScript version of the syntax using tsConfig’s target control. Const /let to var, arrow function to function, async+await to Promise. Then, etc., will not introduce extensions to built-in objects, such as the browser you want to run that does not support Promises. You won’t compile it with a full Promise polyfill, because polyfill still has to work with Core-JS.
Babel is much more scalable
Babel is the perfect choice for custom code conversions and has a rich community of plugins to optimize your code.
TS only supports its own Transformer API, which is far less ecological, less well known and less capable than Babel.
Decorator differences
With the introduction of classes in TS and ES6, proposal-decorators were born, and are our oldest and most familiar friends. But this decorator is not that decorator, and the proposal, now in its third edition over the years, is still stuck in Stage-2.
JS is not the same as TS decorators. JS decorators are still in stage-2 stage, and the current draft version is quite different from TS implementations (TS is based on the first version, JS is currently in its third version). So the final decorator implementation must be quite different.
Second, decorators are not features provided by TS (like types, interfaces), but ECMAScript proposals implemented by TS (like private members of a class). TS actually only supports language features above stage-3, but decorators in JS are still stage-1 when TS introduces decorators for some reason. The TS decorator is actually the first version of the JS decorator proposal.
The Babel compiler needs to use the @babel/plugin-proposal-decorators plugin, which supports three versions of the proposal via the version field:
- “2021-12”
- “2018-09” (default)
- “legacy”
Babel builds to version 2 by default, but to be consistent with TS compilation behavior (i.e., the first version), you need to pass “version”: “Legacy”.
Babel supports more language features
As you can see from the decorator example above, TS only supports language features above stage-3, not features that are still in the draft stage.
Babel’s preset-env supports all standard features, and can support even more features that are not yet standard through various @babel/plugin-proposal-< language features > plug-ins.
They compile at the same speed
In terms of performance, there is not much difference. Here you might wonder: “Babel should compile faster than TS without the type checking step.”
According to the benchmark of the SWC-Node document, TS compiles faster than Babel with type checking turned off.
Esbuild X 510 OPS/SEC ±1.28% (88 runs time) @swC-node/Core x 438 OPS/SEC ±1.00% (88 runs time) typescript x 28.83 Ops/SEC ±10.20% (52 runs time) Babel x 24.21 OPS/SEC ±10.66% (46 runs time) Transform RXJS /AjaxObservable benchmark bench suite: Fastest is esbuildCopy the code
There’s also a third-party plugin fork-ts-checker-webpack-plugin to speed up the type-checking process (in a separate process), so the overall performance isn’t that different.
Babel is a smaller product
Because TS can’t polyfill automatically, core-JS can’t polyfill on demand.
To configure @babel/preset-env:
useBuiltIns: "usage"
- Adding a Target Browser
Targets: < Compatible browser required >
Polyfills can be added precisely based on compilation goals and project API usage, which can greatly reduce package size.
UseBuiltIns: “usage” adds polyfill globally, which pollutes the global environment. You can use the @babel/ plugin-transform-Runtime plugin to provide a sandbox environment for your library code, introducing polyfills into modularity and avoiding global contamination while reusing code.
conclusion
To sum up, both have their own compilation methods. Overall, the only disadvantage of Babel is that it does not have type checking, but you can use TSC –noEmit to check types separately.
Therefore, if the project:
- With Babel and TypeScript already available, it is best to compile code using Babel, use TS for type checking and generate.d. TS files.
This is also recommended in the TS documentation, but if the build output file is not very different from the source code, you can compile directly with TS.
- Only TypeScript can keep the status quo, and in the future, if you need Babel’s capabilities, you can either compile TS JS output using Babel, or compile TS files directly using Babel.
- Babel alone, TypeScript is recommended for incremental transformation of projects to ensure front-end quality.
Thanks for your support
If this article has been helpful to you, please give me a like.
My public account “Xiao Li’s front-end cabin” has just been created, and is still improving. Pay attention to me and become stronger together!