前端html2canvas生成截圖實(shí)現(xiàn)步驟與踩坑記錄
需求:
點(diǎn)擊下載可以導(dǎo)出組件的截圖及數(shù)據(jù)信息文件
分析:
前端生成組件截圖,帶著其他參數(shù)傳給后端,拿到excel文件并下載。關(guān)鍵在于生成組件的截圖,這里通過html2canvas插件來實(shí)現(xiàn)。
實(shí)現(xiàn)步驟
1.下載插件
npm install html2canvas
2.引入
import html2canvas from 'html2canvas'
3.通過ref拿到要下載組件的dom元素
//下載圖標(biāo),綁定下載事件 <i class="el-icon-download" style="cursor: pointer;" @click="download"></i> //需要生成截圖的部分 <div class='wrapper' ref='screen'> ... </div>
4.通過html2canvas生成截圖
download() { //el的全局loading,根據(jù)需求,可加可不加,在下載完成時(shí)或請(qǐng)求完成時(shí)用 loading.close()關(guān)閉 const loading = this.$loading({ lock: true, text: '文件下載中', spinner: 'el-icon-loading', background: 'rgba(0, 0, 0, 0.8)' }); html2canvas(this.$refs.screen, { backgroundColor: null,//畫布背景色(如果未在DOM中指定)。設(shè)置null為透明 useCORS: true, //允許跨域 scale: 1 //用于渲染的比例 }).then((canvas) => { // 此時(shí)已經(jīng)生成我們想要的截圖,可以下載查看 const url = canvas.toDataURL('image/png') //轉(zhuǎn)圖片鏈接,為圖片的base64形式 const a = document.createElement('a') const event = new MouseEvent('click') a.download = '圖片' a.href = url a.dispatchEvent(event) loading.close() // 轉(zhuǎn)為png格式文件格式傳以給后端 // formData即為我們要傳的內(nèi)容,如果還有其他參數(shù)要傳輸可以通過formData.append('key',value)來添加 const formData = new FormData() canvas.toBlob(function(blob) { formData.append('image', blob, 'image.png') }) }) },
可能遇到的問題
1.圖片跨域
因?yàn)轫?xiàng)目的圖片資源是托管在另一個(gè)平臺(tái)上,在生成截圖時(shí),原有dom的圖片由于跨域 canvas “被污染”,一直無法生成,嘗試了多種辦法,設(shè)置useCORS: true且給img標(biāo)簽設(shè)crossorigin="anonymous"也無法解決。最后找到兩種解決方案:一種是把圖片轉(zhuǎn)為編碼格式base64,此方法可以純前端解決該問題,另一種是修改服務(wù)端的配置來解決跨域問題。采用的是第一種方案,附上轉(zhuǎn)base64的方法。(但這種方法也會(huì)有代碼冗余體積增大,可讀性降低等缺點(diǎn))
imgUrlToBase64(imgUrl) { const image = new Image(); image.setAttribute('crossOrigin', 'anonymous'); const imageUrl = imgUrl; image.src = imageUrl // image.onload為異步加載 image.onload = () => { var canvas = document.createElement('canvas'); canvas.width = image.width; canvas.height = image.height; var context = canvas.getContext('2d'); context.drawImage(image, 0, 0, image.width, image.height); var quality = 0.8; const dataurl = canvas.toDataURL('image/png', quality); console.log(dataurl, 'dataurl64') } },
2.css樣式丟失
html2canvas的屏幕截圖是基于 DOM 的,不會(huì)生成實(shí)際的屏幕截圖,而是基于頁面上可用的信息構(gòu)建屏幕截圖,html2canvas庫(kù)對(duì)以下樣式可能無效或不完全支持:
- CSS動(dòng)畫和過渡效果:html2canvas庫(kù)在截圖時(shí)不會(huì)觸發(fā)CSS動(dòng)畫和過渡效果,只會(huì)捕捉到元素的初始狀態(tài)。
- CSS偽元素(如::before和::after):html2canvas庫(kù)無法捕捉到CSS偽元素的樣式。
- CSS濾鏡效果:html2canvas庫(kù)無法捕捉到CSS濾鏡效果(如blur、grayscale等)。
- CSS變量(CustomProperties):html2canvas庫(kù)無法解析和應(yīng)用CSS變量。
- SVG圖像:html2canvas庫(kù)對(duì)SVG圖像的支持有限,可能無法正確渲染和捕捉SVG圖像。
生成截圖的其他方案domtoimage
由于html2canvas這個(gè)插件在生成截圖的時(shí)候有很多弊端,在canvas繪制時(shí)耗時(shí)長(zhǎng),且繪制時(shí)屏幕會(huì)阻塞無法操作,后續(xù)截圖選擇了其他方案,使用domtoimage發(fā)現(xiàn)絲滑很多,可參考文章使用domtoimage生成截圖。
總結(jié)
到此這篇關(guān)于前端html2canvas生成截圖實(shí)現(xiàn)步驟與踩坑記錄的文章就介紹到這了,更多相關(guān)前端html2canvas生成截圖內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript從數(shù)組(數(shù)組對(duì)象)中刪除特定數(shù)據(jù)的方法
這篇文章主要給大家介紹了關(guān)于JavaScript從數(shù)組(數(shù)組對(duì)象)中刪除特定數(shù)據(jù)的相關(guān)資料,js在前臺(tái)界面中舉足輕重,在使用js刪除數(shù)組時(shí)遇到一些問題,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09js+csss實(shí)現(xiàn)的一個(gè)帶復(fù)選框的下拉框
用js+csss實(shí)現(xiàn)的一個(gè)帶復(fù)選框的下拉框,用到了很基礎(chǔ)的技術(shù),但是比較實(shí)用,喜歡的朋友可以參考下2014-09-09js實(shí)現(xiàn)簡(jiǎn)單div拖拽功能實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)簡(jiǎn)單div拖拽功能的方法,實(shí)例分析了javascript針對(duì)div層拖拽的實(shí)現(xiàn)技巧,需要的朋友可以參考下2015-05-05獲取當(dāng)前按鈕或者h(yuǎn)tml的ID名稱實(shí)例(推薦)
下面小編就為大家?guī)硪黄@取當(dāng)前按鈕或者h(yuǎn)tml的ID名稱實(shí)例(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06javascript中的float運(yùn)算精度實(shí)例分析
javascript中的float運(yùn)算精度的一些問題,下面是具體的說明。2010-08-08js如何查找json數(shù)據(jù)中的最大值和最小值方法
這篇文章主要介紹了js如何查找json數(shù)據(jù)中的最大值和最小值方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04