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.
@happy-dom/server-rendering
Advanced tools
Server side rendering of web components with happy-dom.
:warning: This package is deprecated. Happy DOM now supports Declarative Shadow DOM which can be used for server-side rendering of web components instead. :warning:
Happy DOM is a JavaScript implementation of a web browser without its graphical user interface. It includes many web standards from WHATWG DOM and HTML.
The goal of Happy DOM is to emulate enough of a web browser to be useful for testing, scraping web sites and server-side rendering.
Happy DOM focuses heavily on performance and can be used as an alternative to JSDOM.
This package makes it easier to setup servering side rendering of web components by handling the setup of the Node VM Context for you.
Custom Elements (Web Components)
Shadow Root (Shadow DOM)
Declarative Shadow DOM
Mutation Observer
Tree Walker
Fetch
And much more..
npm install @happy-dom/server-rendering
import { HappyDOMContext } from '@happy-dom/server-rendering';
import { Script } from 'vm';
const context = new HappyDOMContext();
const result = await context.render({
url: 'http://localhost:8080',
evaluateScripts: true,
html: `
<html>
<head>
<title>Test page</title>
</head>
<body>
<div class="container">
<!–– Content will be added here -->
</div>
</body>
</html>
`,
// Optional scripts
scripts: [
new Script(`
const element = document.createElement('div');
const container = document.querySelector('.container');
element.innerHTML = 'Test';
container.appendChild(element);
`)
],
// Optional custom element settings
customElements: {
// Converts custom-elements to normal elements
openShadowRoots: true,
// Extracts CSS from shadow roots
extractCSS: true,
// Scopes extracted CSS
scopeCSS: true,
// Adds CSS to head
addCSSToHead: true
}
});
// Outputs: <html><head><title>Test page</title></head><body><div class="container"><div>Test</div></div></body></html>
console.log(result);
The functionality of CSS scoping has not been completed, so you may encounter some problem where CSS is not scoped correctly.
Operation | JSDOM | Happy DOM |
---|---|---|
Import / Require | 333 ms | 45 ms |
Parse HTML | 256 ms | 26 ms |
Serialize HTML | 65 ms | 8 ms |
Render custom element | 214 ms | 19 ms |
querySelectorAll('tagname') | 4.9 ms | 0.7 ms |
querySelectorAll('.class') | 6.4 ms | 3.7 ms |
querySelectorAll('[attribute]') | 4.0 ms | 1.7 ms |
querySelectorAll('[class~="name"]') | 5.5 ms | 2.9 ms |
querySelectorAll(':nth-child(2n+1)') | 10.4 ms | 3.8 ms |
FAQs
Server side rendering of web components with happy-dom.
The npm package @happy-dom/server-rendering receives a total of 3 weekly downloads. As such, @happy-dom/server-rendering popularity was classified as not popular.
We found that @happy-dom/server-rendering demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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.