Security News
Node.js EOL Versions CVE Dubbed the "Worst CVE of the Year" by Security Experts
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
@babel/generator
Advanced tools
The @babel/generator package is a part of the Babel toolchain that is responsible for generating code from an Abstract Syntax Tree (AST). It takes an AST as input and turns it into code with source maps, if desired. This is particularly useful when you want to transform code using Babel and then generate the transformed code.
Code Generation from AST
This feature allows you to generate code from an AST. The code sample demonstrates parsing a piece of code into an AST and then generating the code back from the AST.
const { parse } = require('@babel/parser');
const generate = require('@babel/generator').default;
const code = 'let a = 1;';
const ast = parse(code);
const output = generate(ast, {}, code);
console.log(output.code);
Source Map Support
This feature enables the generation of source maps along with the generated code. The code sample shows how to generate a source map for the code that is being generated from an AST.
const { parse } = require('@babel/parser');
const generate = require('@babel/generator').default;
const code = 'let a = 1;';
const ast = parse(code);
const output = generate(ast, { sourceMaps: true }, code);
console.log(output.map);
Escodegen is an ECMAScript code generator that takes an AST and converts it back into code. It is similar to @babel/generator but does not provide the same level of integration with the Babel ecosystem.
Recast is a JavaScript AST tool that allows you to parse, visit, and transform the nodes of your AST, and then regenerate JavaScript code. It preserves the original formatting as much as possible and can be used in conjunction with Babel.
Astring is a tiny and fast JavaScript code generator from an ESTree-compliant AST. It is smaller and may be faster than @babel/generator but lacks the extensive plugin system and integrations that Babel offers.
Turns an AST into code.
See our website @babel/generator for more information or the issues associated with this package.
Using npm:
npm install --save-dev @babel/generator
or using yarn:
yarn add @babel/generator --dev
v7.26.5 (2025-01-10)
babel-parser
import.defer()
form of import defer
(@babel-bot)babel-plugin-transform-block-scoped-functions
isInStrictMode
in Babel 7 (@liuxingbaoyu)babel-plugin-transform-typescript
babel-parser
@(a.b)()
(@liuxingbaoyu)babel-generator
, babel-parser
, babel-plugin-transform-flow-strip-types
, babel-types
babel-compat-data
, babel-preset-env
transform-typeof-symbol
compat data (@liuxingbaoyu)babel-generator
, babel-parser
, babel-types
babel-plugin-transform-nullish-coalescing-operator
FAQs
Turns an AST into code.
The npm package @babel/generator receives a total of 46,754,753 weekly downloads. As such, @babel/generator popularity was classified as popular.
We found that @babel/generator demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 4 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Critics call the Node.js EOL CVE a misuse of the system, sparking debate over CVE standards and the growing noise in vulnerability databases.
Security News
cURL and Go security teams are publicly rejecting CVSS as flawed for assessing vulnerabilities and are calling for more accurate, context-aware approaches.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.