亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

怎么用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

马尔康县| 黔西县| 弥渡县| 当涂县| 老河口市| 大邑县| 贡山| 松原市| 阳谷县| 保靖县| 荣成市| 郸城县| 西城区| 从化市| 太原市| 曲沃县| 龙川县| 新河县| 福泉市| 盐池县| 古交市| 涞水县| 黄浦区| 宜阳县| 桂东县| 无棣县| 慈溪市| 永安市| 新巴尔虎左旗| 淮滨县| 巴南区| 宣恩县| 娄底市| 内乡县| 柏乡县| 泰来县| 若尔盖县| 普兰店市| 苏尼特左旗| 深圳市| 社会|