Quickly generate image from DOM node using HTML5 canvas and SVG
Fork from html-to-image
English | 简体中文
npm i modern-screenshot
import { domToPng } from 'modern-screenshot'
domToPng(document.querySelector('#app')).then((dataUrl) => {
const link = document.createElement('a')
link.download = 'screenshot.png'
link.href = dataUrl
link.click()
})
CDN
<script src="https://unpkg.com/modern-screenshot"></script>
<script>
modernScreenshot.domToPng(document.querySelector('body')).then(dataUrl => {
const link = document.createElement('a')
link.download = 'screenshot.png'
link.href = dataUrl
link.click()
})
</script>
Browser Console
⚠️ Partial embedding will fail due to CORS
const script = document.createElement('script')
script.src = 'https://unpkg.com/modern-screenshot'
document.getElementsByTagName('head')[0].appendChild(script)
script.onload = () => {
modernScreenshot
.domToImage(document.querySelector('body'), {
debug: true,
progress: (current, total) => {
console.log(`${current}/${total}`)
}
})
.then((img) => {
const width = 600
const height = img.height * (width / img.width)
console.log('%c ', [
`padding: 0 ${width / 2}px;`,
`line-height: ${height}px;`,
`background-image: url('${img.src}');`,
`background-size: 100% 100%;`,
].join(''))
})
}
method(node: Node, options?: Options)
DOM to dataURL
DOM to data
DOM to HTMLElement
See the options.ts
Quick screenshots per second by reusing context and web worker
import { createContext, destroyContext, domToPng } from 'modern-screenshot'
// use vite
import workerUrl from 'modern-screenshot/worker?url'
async function screenshotsPerSecond() {
const context = await createContext(document.querySelector('#app'), {
workerUrl,
workerNumber: 1,
})
for (let i = 0; i < 10; i++) {
domToPng(context).then((dataUrl) => {
const link = document.createElement('a')
link.download = `screenshot-${i + 1}.png`
link.href = dataUrl
link.click()
if (i + 1 === 10) {
destroyContext(context)
}
})
await new Promise(resolve => setTimeout(resolve, 1000))
}
}
screenshotsPerSecond()
See the context.ts
-
unable to clone css counters
content: counter(step);
- 2025-01-08: add
reduceFontSizeFactor
option to reduce font size - 2025-01-08: add
dom-to-image2
method to export dom to image using blobs and 1 reusable canvas - 2025-01-08: add
dom-to-svg-image
method to export dom to svg image