Research
Security News
Malicious npm Package Typosquats react-login-page to Deploy Keylogger
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
@babel/helper-builder-react-jsx
Advanced tools
Package description
@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.
Readme
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
Unknown package
The npm package @babel/helper-builder-react-jsx receives a total of 423,908 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
Socket researchers unpack a typosquatting package with malicious code that logs keystrokes and exfiltrates sensitive data to a remote server.
Security News
The JavaScript community has launched the e18e initiative to improve ecosystem performance by cleaning up dependency trees, speeding up critical parts of the ecosystem, and documenting lighter alternatives to established tools.
Product
Socket now supports four distinct alert actions instead of the previous two, and alert triaging allows users to override the actions taken for all individual alerts.