中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用vue實現網頁截圖

發布時間:2021-11-17 14:28:02 來源:億速云 閱讀:454 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關怎么用vue實現網頁截圖的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

1、安裝html2Canvas

npm install html2canvas --save

2、在需要的vue組件中引入

import html2canvas from "html2canvas";

3、編寫一個截圖按鈕

<el-button class="button-dalod" size="mini" title="生成圖片" @click="toImage()" icon="el-icon-download"></el-button>

4、調用函數toImage

// 頁面元素轉圖片
        toImage () {
            // 手動創建一個 canvas 標簽
            const canvas = document.createElement("canvas")
            // 獲取父標簽,意思是這個標簽內的 DOM 元素生成圖片
            // imageTofile是給截圖范圍內的父級元素自定義的ref名稱
            let canvasBox = this.$refs.imageTofile
            // 獲取父級的寬高
            const width = parseInt(window.getComputedStyle(canvasBox).width)
            const height = parseInt(window.getComputedStyle(canvasBox).height)
            // 寬高 * 2 并放大 2 倍 是為了防止圖片模糊
            canvas.width = width * 2
            canvas.height = height * 2
            canvas.style.width = width + 'px'
            canvas.style.height = height + 'px'
            const context = canvas.getContext("2d");
            context.scale(2, 2);
            const options = {
                backgroundColor: null,
                canvas: canvas,
                useCORS: true
            }
            html2canvas(canvasBox, options).then((canvas) => {
                // toDataURL 圖片格式轉成 base64
                let dataURL = canvas.toDataURL("image/png")
                console.log(dataURL)
                this.downloadImage(dataURL)
            })
        },
        //下載圖片
        downloadImage(url) {
            // 如果是在網頁中可以直接創建一個 a 標簽直接下載 
            let a = document.createElement('a')
            a.href = url
            a.download = '首頁截圖'
            a.click()
        },

別忘了給頁面所在截圖范圍內的父級添加ref屬性,方便canvas找到父級計算寬高從而截屏

怎么用vue實現網頁截圖

這就是截圖出來的效果:

怎么用vue實現網頁截圖 

感謝各位的閱讀!關于“怎么用vue實現網頁截圖”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

托里县| 大渡口区| 台中县| 文昌市| 武城县| 福建省| 广昌县| 门头沟区| 德阳市| 景宁| 东丰县| 邻水| 凤庆县| 澜沧| 昌图县| 揭西县| 姚安县| 新河县| 牡丹江市| 宁都县| 武鸣县| 益阳市| 龙川县| 灵川县| 诸城市| 嵩明县| 白玉县| 诏安县| 山西省| 鸡泽县| 宜丰县| 靖江市| 东山县| 龙口市| 徐汇区| 亚东县| 会宁县| 青河县| 额敏县| 潜江市| 陈巴尔虎旗|