html2Canvas截图包含滚动条解决思路

概况描述

在项目中使用html2Canvas进行截图时发现无法截取滚动条部分,前端是使用vue2的版本,网上找了很多方式都没效果,冷静思考后,给出解决办法。

解决思路

当我们截取的div容器的宽和高与内部的子容器div的宽和高不一样时,内部div就会出现滚动条,因为我们截取的div与内部div的宽和高不一致,所以截取时只能截取我们定位的div,无法截取到滚动条部分。

在截取时将定位的div宽和高改为和内部div容器的宽和高一致,截取时就能包含滚动条部分,截取结束后将定位的div的宽和高恢复原来的值,让界面正常

图片展示 

  • 原来包含滚动条的界面

  •  html2Canvas截取的图片(未添加处理办法时)

  • 使用上面处理思路后的截图

  • 解决思路的代码

  

<div class="about" id="capture" ref="capture"><!-- 内部容器div此处就省略了-->
</div>

let targetDom = this.$refs.capture;   //原本需要截图的divthis.$nextTick(() => {const swidth = document.querySelector('.gantt_data_area'); // 定位到内层出现滚动条div宽度targetDom.style.width = `${swidth.offsetWidth+250}px`;setTimeout(() => {html2canvas(targetDom,{dpi: window.devicePixelRatio * 4,scale: 4,useCORS: true, //允许canvas画布内可以跨域请求外部链接图片, 允许跨域请求。allowTaint: false,height: targetDom.scrollHeight,  //画布高度(包含未显示的滚动部分)width: targetDom.scrollWidth,  //画布高度(包含未显示的滚动部分)windowWidth: targetDom.scrollWidth,windowHeight: targetDom.scrollHeight,}).then((canvas) => {var imgUri = canvas.toDataURL('image/png').replace('image/png', 'image/octet-stream') // 获取生成的图片的urlvar saveLink = document.createElement('a')saveLink.href = imgUrisaveLink.download = 'downLoad.png'saveLink.click()targetDom.style.width = '100%'; // 截图结束后需要将修改的宽度高度恢复targetDom.style.height = '100%';});}, 1000);});

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/1598.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

如何写好单片机毕业设计的论文

如何写好单片机毕业设计的论文 引言 单片机毕业设计是大学生在专业课程中的重要组成部分,它不仅要求学生能够独立进行科学研究,还要求学生能够将自己的研究成果进行合理的总结和表达。本文将从选题、论文结构、写作技巧等方面,探讨如何写好单片机毕业设计的论文。 选题 …

Django模型的属性与方法

本节介绍Django模型的属性和方法&#xff0c;以及如何重写之前定义的模型方法等内容。 3.5.1 模型属性 Django模型中最重要的属性就是Manager&#xff0c;它是Django模型和数据库查询操作之间的接口&#xff0c;并且被用作从数据库当中获取实例的途径。如果Django模型中没有…

Web开发之v-model和model-value区别

v-model 和 model-value 是在处理表单数据绑定时使用的不同概念&#xff0c;它们分别服务于不同的目的和场景。 1、v-model 用于实现组件内部的双向数据绑定&#xff0c;特别适用于表单元素和支持双向绑定的自定义组件。语法简洁&#xff0c;可以直接在组件模板中使用&#x…

什么是Java Spring框架?

Java Spring框架是一个开放源代码的J2EE应用程序框架&#xff0c;由Rod Johnson在2002年提出并创建。它的主要目标是解决企业级编程开发中的复杂性&#xff0c;实现敏捷开发。Spring框架是一个轻量级的容器&#xff0c;主要用于管理bean的生命周期。它解决了开发者在J2EE开发中…

JAVA学习笔记27(异常)

1.异常 ​ *异常(Exception) ​ *快捷键 ctrl alt t 选中try - catch ​ *如果进行了异常处理&#xff0c;那么即使出现了异常&#xff0c;程序可以继续执行 1.1 基本概念 ​ *在Java语言中&#xff0c;将程序执行中发生的不正常情况称为"异常"(开发过程中的语…

CVE-2024-21887)Ivanti 远程命令注入漏洞

CVE-2024-21887&#xff09;Ivanti 远程命令注入漏洞 一、漏洞简介 Ivа&#xff4e;ti Cоnnесt Sесurе&#xff08;9.х、22.х&#xff09;和 Ivаnti Pоliсу Sесurе 的 Wеb 组件中存在一个命令注入漏洞&#xff0c;使得经过身份验证的管理员能够发送特别构建…

python scrapy 爬取豆瓣电影top250教程2

文章目录 scrapy top250教程1scrapy pipeline将数据写入数据库下载中间件middleware的使用从下层页面爬取详细电影信息运行代码scrapy top250教程1 python scrapy 爬取豆瓣电影top250教程 scrapy pipeline将数据写入数据库 mysql创建表use test; drop TABLE tb_top_movie

MySQL行格式(row format)

MySQL行格式&#xff08;row format&#xff09; 表的行格式决定了其行的物理存储方式&#xff0c;这反过来又会影响查询和 DML 操作的性能。随着单个磁盘页面容纳更多行&#xff0c;查询和索引查找可以更快地工作&#xff0c;缓冲池中需要的高速缓存内存更少&#xff0c;写出…

Nginx的ssl证书配置

http协议数据传输都是明文的。 https是httpssl&#xff0c;ssl是加密协议&#xff0c;通过证书来加密&#xff0c;安装了证书的网站才会用https来交互。 # 再nginx的配置文件的server这中配置 server {#listen 80;listen 443 ssl; #http默认端口是80&#xff0c; …

爬虫f12跳转和debugger检测

在空白页面的控制台运行解决重定向再复制url到网页 //解决重定向 (() > {window.onbeforeunload ()>{debugger;return false;}})();//构造方法无限debugger (() > {Function.prototype.constructor Function.prototype.constructor;Function.prototype.constructor…

nacos 2022.0.0.0 版本实现负载均衡及集群

一、loadbalancer实现负载均衡 新版本的nacos已经取消了对ribbon的支持&#xff0c;所以不能使用ribbon来实现nacos提供的负载均衡。 但是新版本中我们可以使用loadbalancer实现负载均衡。 二、导入loadbalancer坐标 1、原本的坐标&#xff1a; 在parent的pom.xml中 <p…

Python 学习笔记(十一)—— 异常处理

目录 一、异常简介 二、捕获异常 2.1 捕获特定类型的异常 2.2 捕获多个类型的异常 2.3 捕获所有类型的异常 2.4 使用多个except块处理不同类型的异常 三、异常的传递 3.1 异常在函数内部引发&#xff0c;并在函数外部捕获 3.2 异常在多层函数调用中传递 3.3 异常在类…

耐高温300度锅炉轴承,江苏鲁岳轴承制造的行业标杆

自润滑轴承-产品类型-耐高温轴承-不锈钢轴承-江苏鲁岳轴承制造有限公司。锅炉轴承&#xff0c;耐高温至200度-800度。 江苏鲁岳轴承制造有限公司&#xff0c;一家专注于锅炉轴承和耐高温轴承的研发与生产的企业&#xff0c;致力于为客户提供高质量、高性能的轴承解决方案。其中…

使用 OpenCV 测量物体尺寸

使用 OpenCV 测量物体尺寸 你是否曾经遇到过这样的问题&#xff1a;想要知道计算器的精确尺寸&#xff0c;但手头又没有专业的测量工具&#xff1f;别担心&#xff0c;今天我们就来教大家一个简单又实用的方法&#xff0c;通过一张A4纸就能估算出计算器的宽度和高度&#xff0c…

笔记:Python 选择结构练习题

文章目录 前言一、选择结构 是什么&#xff1f;二、练习题1.选择题2.填空题 总结 前言 选择结构在编程中扮演着至关重要的角色&#xff0c;它允许程序根据条件的满足与否选择不同的路径执行代码。在Python中&#xff0c;我们通常使用if语句来实现选择结构。if语句允许我们根据…

iZotope RX 10 音频修复和增强工具 mac/win

iZotope RX 10 for Mac是一款出色的音频修复和增强工具&#xff0c;凭借其卓越的音频处理技术&#xff0c;能够轻松应对各种音频问题。 无论是背景噪音、回声还是失真&#xff0c;RX 10都能精准去除&#xff0c;还原清晰纯净的音频。同时&#xff0c;它还提供了丰富的增强工具&…

【Linux系统编程】第六弹---权限的概念

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】 目录 1、什么是权限 2、权限的本质 3、Linux中的用户 4、Linux中文件的权限 4.1、文件访问者的分类(角色) 4.2、文件类型和访问权…

算法刷题记录 Day52

算法刷题记录 Day52 Date: 2024.04.20 lc 84. 柱状图中最大的矩形 // 单调栈 class Solution { public:int largestRectangleArea(vector<int>& heights) {// 对于每个柱子&#xff0c;我们考虑按当前柱子进行中心扩散&#xff0c;直到找到其左侧及其右侧&#xf…

Python 全栈安全(三)

原文&#xff1a;annas-archive.org/md5/712ab41a4ed6036d0e8214d788514d6b 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 第十一章&#xff1a;OAuth 2 本章内容 注册 OAuth 客户端 请求对受保护资源的授权 授权而不暴露身份验证凭据 访问受保护的资源 OAuth …

人脑是怎么防止梯度消失和梯度爆炸的

人脑是怎么防止梯度消失和梯度爆炸的? 神经网络&#xff0c;也称为人工神经网络 (ANN) 或模拟神经网络 (SNN)&#xff0c;是机器学习的子集&#xff0c;并且是深度学习算法的核心。其名称和结构是受人类大脑的启发&#xff0c;模仿了生物神经元信号相互传递的方式。 感觉这个问…