Security News
Opengrep Emerges as Open Source Alternative Amid Semgrep Licensing Controversy
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
als-render-jsx
Advanced tools
als-render-jsx
is a JavaScript library that transforms JSX-like code into plain JavaScript. It is designed to mimic JSX syntax while enabling runtime evaluation and rendering in both Node.js and browser environments.
als-render-jsx
is intended to work with the als-component
library, seamlessly integrating JSX-like components into projects.RenderJsx.componentFn
— to define how components are rendered.RenderJsx.buildAction
— to define how event handlers are processed.Install the library using npm:
npm i als-render-jsx
In a Node.js environment, import the library as follows:
const RenderJsx = require('als-render-jsx');
In the browser, include the library using a script tag:
Development Version
<script src="/node_modules/als-render-jsx/render-jsx.js"></script>
Minified Production Version
<script src="/node_modules/als-render-jsx/render-jsx.min.js"></script>
Use the RenderJsx.render
method to transform JSX-like code into plain JavaScript.
const component = /*js*/`function Some() {
const inner = 'Hello world!';
return (<div>{inner}</div>);
}`;
const result = RenderJsx.render(component);
console.log(result);
function Some() {
const inner = 'Hello world!';
return `<div>${inner}</div>`;
}
const component = /*js*/`function Parent() {
return (<div><Child>some inner</Child></div>);
}`;
const result = RenderJsx.render(component);
console.log(result);
function Parent() {
return `<div>${(new Child({}, \`some inner\`)).call()}</div>`;
}
componentFn
and buildAction
als-render-jsx
allows you to redefine two core functions to suit your needs.
RenderJsx.componentFn(isAwait, tagName, props, inner)
This function defines how components are rendered. By default, it returns an initialization of another component.
RenderJsx.componentFn = function (isAwait, tagName, props, inner) {
return `${isAwait}(new ${tagName}(${props}, \`${inner}\`)).call()`;
};
async={true}
prop in the JSX, the isAwait
parameter becomes true
.You can customize the function to return a string representation for debugging:
RenderJsx.componentFn = function (isAwait, tagName, props, inner) {
return `Debug: { isAwait: ${isAwait}, tagName: ${tagName}, props: ${props}, inner: ${inner} }`;
};
RenderJsx.buildAction([name, value])
This function processes event handlers and assigns listeners after the HTML is rendered.
RenderJsx.buildAction = function ([name, value]) {
const event = name.split('on')[1].toLowerCase();
value = `$${this.action('${event}', ${value})}`;
return [event, value];
};
Customize it to log all event assignments:
RenderJsx.buildAction = function ([name, value]) {
console.log(`Assigning event: ${name} with handler: ${value}`);
return [name, value];
};
const components = /*js*/`function Parent() {
return (<div><Child prop="value">Hello</Child></div>);
}`;
const result = RenderJsx.render(components);
console.log(result);
function Parent() {
return `<div>${(new Child({prop: "value"}, \`Hello\`)).call()}</div>`;
}
componentFn
and buildAction
RenderJsx.componentFn = function (isAwait, tagName, props, inner) {
return `CustomComponent(${tagName}, ${props}, ${inner})`;
};
RenderJsx.buildAction = function ([name, value]) {
return [`custom-${name}`, `handle(${value})`];
};
const components = /*js*/`function App() {
return (<div onClick={handleClick}>Click Me</div>);
}`;
const result = RenderJsx.render(components);
console.log(result);
function App() {
return `<div custom-onClick="handle(handleClick)">Click Me</div>`;
}
This demonstrates how you can fully control the behavior of the library to match your specific requirements.
FAQs
Transform JSX-like code into plain JavaScript
The npm package als-render-jsx receives a total of 7 weekly downloads. As such, als-render-jsx popularity was classified as not popular.
We found that als-render-jsx demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 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
Opengrep forks Semgrep to preserve open source SAST in response to controversial licensing changes.
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.