Research
Security News
Threat Actor Exposes Playbook for Exploiting npm to Build Blockchain-Powered Botnets
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
@babel/helper-builder-react-jsx
Advanced tools
@babel/helper-builder-react-jsx is a Babel helper module that assists in transforming JSX syntax into JavaScript. It is primarily used internally by Babel plugins to handle JSX transformations, making it easier to convert JSX elements into the corresponding React.createElement calls or other custom JSX pragma functions.
Transform JSX to React.createElement
This feature allows you to transform a JSX element into a React.createElement call. The code sample demonstrates how to create a JSX element and then transform it into a React.createElement call using the @babel/helper-builder-react-jsx package.
const t = require('@babel/types');
const buildElement = require('@babel/helper-builder-react-jsx');
const jsxElement = t.jSXElement(
t.jSXOpeningElement(t.jSXIdentifier('div'), [], false),
t.jSXClosingElement(t.jSXIdentifier('div')),
[t.jSXText('Hello, world!')],
false
);
const reactElement = buildElement({
tagExpr: t.identifier('React.createElement'),
tagName: 'div',
args: [t.stringLiteral('div'), t.nullLiteral(), t.stringLiteral('Hello, world!')]
});
console.log(reactElement);
Custom JSX Pragma
This feature allows you to transform a JSX element using a custom JSX pragma function instead of React.createElement. The code sample demonstrates how to create a JSX element and then transform it using a custom pragma function called MyCustomPragma.
const t = require('@babel/types');
const buildElement = require('@babel/helper-builder-react-jsx');
const jsxElement = t.jSXElement(
t.jSXOpeningElement(t.jSXIdentifier('MyComponent'), [], false),
t.jSXClosingElement(t.jSXIdentifier('MyComponent')),
[t.jSXText('Hello, custom pragma!')],
false
);
const customPragmaElement = buildElement({
tagExpr: t.identifier('MyCustomPragma'),
tagName: 'MyComponent',
args: [t.stringLiteral('MyComponent'), t.nullLiteral(), t.stringLiteral('Hello, custom pragma!')]
});
console.log(customPragmaElement);
babel-plugin-transform-react-jsx is a Babel plugin that transforms JSX syntax into React.createElement calls. It is similar to @babel/helper-builder-react-jsx in that it handles JSX transformations, but it is a higher-level plugin that can be used directly in a Babel configuration.
babel-plugin-jsx-pragmatic is a Babel plugin that allows you to specify a custom JSX pragma function to use instead of React.createElement. It provides similar functionality to @babel/helper-builder-react-jsx's custom pragma feature but is designed to be used as a standalone Babel plugin.
babel-plugin-transform-vue-jsx is a Babel plugin that transforms JSX syntax into Vue render function calls. While it serves a similar purpose to @babel/helper-builder-react-jsx, it is specifically designed for use with Vue.js instead of React.
Helper function to build react jsx
See our website @babel/helper-builder-react-jsx for more information.
Using npm:
npm install --save-dev @babel/helper-builder-react-jsx
or using yarn:
yarn add @babel/helper-builder-react-jsx --dev
FAQs
Helper function to build react jsx
The npm package @babel/helper-builder-react-jsx receives a total of 691,753 weekly downloads. As such, @babel/helper-builder-react-jsx popularity was classified as popular.
We found that @babel/helper-builder-react-jsx 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.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.
Security News
NVD’s backlog surpasses 20,000 CVEs as analysis slows and NIST announces new system updates to address ongoing delays.
Security News
Research
A malicious npm package disguised as a WhatsApp client is exploiting authentication flows with a remote kill switch to exfiltrate data and destroy files.