News

Babel 7 JavaScript Compiler Adds TypeScript Support

The popular open source Babel compiler that makes modern JavaScript compatible with older environments has shipped in version 7 and, with help from Microsoft, now supports TypeScript.

Babel, a compiler toolchain, is used by millions of JavaScript developers to convert ECMAScript 2015 and later code into backwards-compatible JavaScript versions to make it work in older Web browsers or other environments.

Unlike many open source projects that have strong backing from corporate dev teams, it's primarily driven by individual volunteers. Those volunteers worked for a year to create Babel 7, shipping it last week. Babel 6 was released almost three years ago.

"We worked with the TypeScript team on getting Babel to parse/transform type syntax with @babel/preset-typescript, similar to how we handle Flow with @babel/preset-flow," said Babel volunteer Henry Zhu in a blog post last week.

Daniel Rosenwasser, the TypeScript guru on the Microsoft dev team, provided more information on the new support.

"Over a year ago, we set out to find what the biggest difficulties users were running into with TypeScript, and we found that a common theme among Babel users was that trying to get TypeScript set up was just too hard," Rosenwasser said. "The reasons often varied, but for a lot of developers, rewiring a build that's already working can be a daunting task."

So, for about a year, the Microsoft team worked with the Babel community volunteers to add TypeScript support to the project. While Babel will compile types to plain JavaScript code, it won't actually do type-checking, which is still the exclusive province of TypeScript. That doesn't do much for existing TypeScript coders, Rosenwasser acknowledged, "But if you're already using Babel, or interested in the Babel ecosystem, and you want to get the benefits of TypeScript like catching typos, error checking, and the editing experiences you might've seen in the likes of Visual Studio and Visual Studio Code, this is for you!"

There are some caveats with the new functionality -- such as a few constructs that don't compile -- and Microsoft still recommends use of its tsc TypeScript compiler for type-checking TypeScript code, which Babel doesn't do.

Besides the TypeScript support, Babel 7 also features a lot of other new functionality. "Babel 7 is a huge release," Zhu said, "we've made it faster, created an upgrade tool, JS configs, config 'overrides,' more options for size/minification, JSX Fragments, TypeScript, new proposals, and more!"

About the Author

David Ramel is an editor and writer at Converge 360.

comments powered by Disqus

Featured

  • New 'Visual Studio Hub' 1-Stop-Shop for GitHub Copilot Resources, More

    Unsurprisingly, GitHub Copilot resources are front-and-center in Microsoft's new Visual Studio Hub, a one-stop-shop for all things concerning your favorite IDE.

  • Mastering Blazor Authentication and Authorization

    At the Visual Studio Live! @ Microsoft HQ developer conference set for August, Rockford Lhotka will explain the ins and outs of authentication across Blazor Server, WebAssembly, and .NET MAUI Hybrid apps, and show how to use identity and claims to customize application behavior through fine-grained authorization.

  • Linear Support Vector Regression from Scratch Using C# with Evolutionary Training

    Dr. James McCaffrey from Microsoft Research presents a complete end-to-end demonstration of the linear support vector regression (linear SVR) technique, where the goal is to predict a single numeric value. A linear SVR model uses an unusual error/loss function and cannot be trained using standard simple techniques, and so evolutionary optimization training is used.

  • Low-Code Report Says AI Will Enhance, Not Replace DIY Dev Tools

    Along with replacing software developers and possibly killing humanity, advanced AI is seen by many as a death knell for the do-it-yourself, low-code/no-code tooling industry, but a new report belies that notion.

  • Vibe Coding with Latest Visual Studio Preview

    Microsoft's latest Visual Studio preview facilitates "vibe coding," where developers mainly use GitHub Copilot AI to do all the programming in accordance with spoken or typed instructions.

Subscribe on YouTube