前端將dom轉(zhuǎn)換成圖片的方法(使用dom-to-image)
一、問題描述
在工作的過程中會(huì)遇到要將dom變成圖片并下載的問題,剛開始使用的html2canvas
進(jìn)行轉(zhuǎn)換的,但是我老大告訴我說,咱們做的是面向國(guó)外的網(wǎng)頁,插件太大會(huì)導(dǎo)致頁面加載慢的問題(國(guó)外部分地區(qū)網(wǎng)絡(luò)沒有國(guó)內(nèi)這么發(fā)達(dá)),就讓我用原生dom或一些比較小的插件,在原生dom下載的時(shí)候遇到了context.drawImage(element, 0, 0, width, height)
這一方法傳入?yún)?shù)要傳類型HTMLCanvasElement的問題,所以要將一個(gè)HTMLElement轉(zhuǎn)換成HTMLCanvasElement,但是經(jīng)過一些信息的查找,我發(fā)現(xiàn)有個(gè)很好用且輕量化的插件,可以完美解決這一問題,所以這里給大家推薦一個(gè)輕量級(jí)的插件dom-to-image
(23kb),這個(gè)插件可以不用進(jìn)行類型轉(zhuǎn)換,直接將dom元素轉(zhuǎn)換成需要的文件格式。
二、dom-to-image的使用
2.1 dom-to-image的安裝
在終端輸入以下代碼進(jìn)行dom-to-image
安裝
npm install dom-to-image
2.2 dom-to-image引入
2.2.1 vue項(xiàng)目引入
在需要使用這個(gè)插件的頁面使用以下代碼進(jìn)行局部引入
import domToImage from 'dom-to-image';
然后就可以通過以下代碼進(jìn)行圖片的轉(zhuǎn)換了
const palGradientGap = document.getElementById('element') const canvas = document.createElement('canvas') canvas.width = element.offsetWidth canvas.height = element.offsetHeight this.domtoimage.toPng(element).then(function (canvas) { const link = document.createElement('a') link.href = canvas link.download = 'image.png' // 下載文件的名稱 link.click() })
當(dāng)然也可以進(jìn)行全局引入
創(chuàng)建一個(gè)domToImage.js
文件寫入以下代碼
import Vue from 'vue'; import domToImage from 'dom-to-image'; const domToImagePlugin = { install(Vue) { Vue.prototype.$domToImage = domToImage; } }; Vue.use(domToImagePlugin);
然后再入口文件main.js
寫入以下代碼全局引入插件
import Vue from 'vue' import App from './App.vue' import './domToImage.js'; // 引入全局插件 Vue.config.productionTip = false new Vue({ render: h => h(App), }).$mount('#app')
三、dom-to-image相關(guān)方法
toSvg(node: Node, options?: Options): Promise<string>
:將 DOM 元素轉(zhuǎn)換為 SVG 圖片,并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
toPng(node: Node, options?: Options): Promise<string>
:將 DOM 元素轉(zhuǎn)換為 PNG 圖片,并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
toJpeg(node: Node, options?: Options): Promise<string>
:將 DOM 元素轉(zhuǎn)換為 JPEG 圖片,并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
toBlob(node: Node, options?: Options): Promise<Blob>
:將 DOM 元素轉(zhuǎn)換為 Blob 對(duì)象,并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
toPixelData(node: Node, options?: Options): Promise<Uint8ClampedArray>
:將 DOM 元素轉(zhuǎn)換為像素?cái)?shù)據(jù),并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
toCanvas(node: Node, options?: Options): Promise<HTMLCanvasElement>
:將 DOM 元素轉(zhuǎn)換為 Canvas 對(duì)象,并返回一個(gè) Promise 對(duì)象。參數(shù)說明:
node
:要轉(zhuǎn)換為圖片的 DOM 元素。options
:可選參數(shù)對(duì)象,用于配置轉(zhuǎn)換選項(xiàng)。
其中,Options
參數(shù)是一個(gè)可選的配置對(duì)象,用于設(shè)置轉(zhuǎn)換選項(xiàng)。以下是一些常用的選項(xiàng):
width
:輸出圖像的寬度,默認(rèn)值為元素的實(shí)際寬度。height
:輸出圖像的高度,默認(rèn)值為元素的實(shí)際高度。style
:要應(yīng)用于元素的樣式對(duì)象。filter
:要應(yīng)用于元素的 CSS 濾鏡。bgcolor
:輸出圖像的背景顏色,默認(rèn)值為透明。quality
:輸出圖像的質(zhì)量,僅適用于 JPEG 格式,默認(rèn)值為 0.92。
總結(jié)
到此這篇關(guān)于前端將dom轉(zhuǎn)換成圖片的文章就介紹到這了,更多相關(guān)前端將dom轉(zhuǎn)換成圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript 錯(cuò)誤處理與調(diào)試經(jīng)驗(yàn)總結(jié)
在Web開發(fā)過程中,編寫JavaScript程序時(shí)或多或少會(huì)遇到各種各樣的錯(cuò)誤,有語法錯(cuò)誤,邏輯錯(cuò)誤。如果是一小段代碼,可以通過仔細(xì)檢查來排除錯(cuò)誤,但如果程序稍微復(fù)雜點(diǎn),調(diào)試JS便成為一個(gè)令Web開發(fā)者很頭痛的問題。2010-08-08JS獲取當(dāng)前時(shí)間戳與時(shí)間戳轉(zhuǎn)日期時(shí)間格式問題
這篇文章主要介紹了JS獲取當(dāng)前時(shí)間戳與時(shí)間戳轉(zhuǎn)日期時(shí)間格式,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-01-01如何使用瀏覽器擴(kuò)展篡改網(wǎng)頁中的JS?文件
這篇文章主要為大家介紹了如何使用瀏覽器擴(kuò)展篡改網(wǎng)頁中的JS文件實(shí)現(xiàn)解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-05-05get(0).tagName獲得作用標(biāo)簽示例代碼
get(0).tagName可獲得作用標(biāo)簽,下面是它的一個(gè)小應(yīng)用,在學(xué)習(xí)js的朋友可以參考下2014-10-10用JavaScript來美化HTML的select標(biāo)簽的下拉列表效果
這篇文章主要介紹了用JavaScript來美化HTML的select標(biāo)簽的下拉列表效果的方法,而且在多瀏覽器下的兼容效果也得到提升,需要的朋友可以參考下2015-11-11