js實(shí)現(xiàn)網(wǎng)頁截圖的兩種方案詳析
方案一:使用 html2canvas 庫(推薦)
原理:將 HTML DOM 元素轉(zhuǎn)換為 Canvas,再導(dǎo)出為圖片
特點(diǎn):兼容性好,支持大部分現(xiàn)代瀏覽器,但需注意 CSS 屬性兼容性
實(shí)現(xiàn)步驟:
1.安裝依賴:
npm install html2canvas
2.基礎(chǔ)截圖代碼:
import html2canvas from "html2canvas" //截取整個(gè)屏幕 const screenFn = () => { const element = document.body html2canvas(element).then((canvas) => { const imgUrl = canvas.toDataURL("image/png") const link = document.createElement("a") link.download = "screenshot.png" link.href = imgUrl link.click() }) } //截取特定元素 const screenFn = () => { const element = document.getElementById("version") if (element) { html2canvas(element, { allowTaint: true, // 允許跨域圖片 useCORS: true, // 使用 CORS 加載圖片 scale: 2, // 提升截圖分辨率 logging: true, // 調(diào)試時(shí)查看日志 scrollY: -window.scrollY // 處理滾動(dòng)位置 }).then((canvas) => { const imgUrl = canvas.toDataURL("image/png") const link = document.createElement("a") link.download = "screenshot.png" link.href = imgUrl link.click() }) } }
方案二: 使用原生 API Window: getDisplayMedia()
原理:通過屏幕共享 API 捕獲當(dāng)前標(biāo)簽頁
特點(diǎn):需用戶授權(quán),適合需要交互式操作的場景
實(shí)現(xiàn)步驟:
const screenFn = async () => { try { const stream = await navigator.mediaDevices.getDisplayMedia({ video: { displaySurface: "browser" } }) const videoTrack = stream.getVideoTracks()[0] const imageCapture = new ImageCapture(videoTrack) const bitmap = await imageCapture.grabFrame() // 將 bitmap 繪制到 canvas const canvas = document.createElement("canvas") canvas.width = bitmap.width canvas.height = bitmap.height const ctx = canvas.getContext("2d") ctx.drawImage(bitmap, 0, 0) // 導(dǎo)出圖片 canvas.toBlob((blob) => { const url = URL.createObjectURL(blob) const a = document.createElement("a") a.href = url a.download = "screenshot.png" a.click() }, "image/png") videoTrack.stop() } catch (err) { console.error("截圖失敗:", err) } }
兩種方案優(yōu)缺點(diǎn):
1.方案一:html2canvas
優(yōu)點(diǎn):純前端實(shí)現(xiàn),靈活度高
缺點(diǎn):復(fù)雜頁面渲染可能有差異
2.方案二:getDisplayMedia
優(yōu)點(diǎn):原生 API,無需額外依賴
缺點(diǎn):需要用戶手動(dòng)選擇分享區(qū)域
總結(jié)
到此這篇關(guān)于js實(shí)現(xiàn)網(wǎng)頁截圖的文章就介紹到這了,更多相關(guān)js網(wǎng)頁截圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中isPrototypeOf函數(shù)作用和使用實(shí)例
這篇文章主要介紹了JavaScript中isPrototypeOf函數(shù)作用和使用實(shí)例,本文講解了它的作用和使用方法以及使用實(shí)例,需要的朋友可以參考下2015-06-06js實(shí)現(xiàn)驗(yàn)證碼干擾(靜態(tài))
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)驗(yàn)證碼干擾,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-02-02JavaScript數(shù)值轉(zhuǎn)換的三種方式總結(jié)
JavaScript數(shù)值轉(zhuǎn)換一般有三種方式,Number(param)函數(shù)、parseInt(param)、parseIFloat(param),下面為大家詳細(xì)介紹,需要的朋友可以參考下2014-07-07JavaScript 和 C++實(shí)現(xiàn)雙向交互
本文主要介紹了在CEF中實(shí)現(xiàn)JavaScript和C++的雙向交互,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2025-02-02微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用)
這篇文章主要介紹了微信小程序自定義彈窗實(shí)現(xiàn)詳解(可通用),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07關(guān)閉瀏覽器輸入框自動(dòng)補(bǔ)齊 兼容IE,FF,Chrome等主流瀏覽器
這篇文章主要介紹了關(guān)閉瀏覽器輸入框自動(dòng)補(bǔ)齊 兼容IE,FF,Chrome等主流瀏覽器,需要的朋友可以參考下。希望對(duì)大家有所幫助2014-02-02使用ngrok+express解決本地環(huán)境中微信接口調(diào)試問題
這篇文章主要介紹了使用ngrok+express解決本地環(huán)境中微信接口調(diào)試問題,需要的朋友可以參考下2018-02-02微信小程序?qū)崿F(xiàn)點(diǎn)餐小程序左側(cè)滑動(dòng)菜單
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)點(diǎn)餐小程序左側(cè)滑動(dòng)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07