将前端HTML页面生成图片,用html2canvas.js将前端HTML页面生成图片
时间:2021-08-30
本文章向大家介绍将前端HTML页面生成图片,用html2canvas.js将前端HTML页面生成图片,主要包括将前端HTML页面生成图片,用html2canvas.js将前端HTML页面生成图片使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
首先去html2canvas官网下载html2canvas.js文件
html2canvas官网地址:http://html2canvas.hertzen.com/
HTML
<div id="host_file" class="container"> <div id="view" class="print_wrap"> <div class="host_file_top_title_box"> <p>111111111111</p> <p>111111111111</p> </div> <div id="moveDiv" @click="renderPdf">下载</div> </div> </div>
js
renderPdf() { var dom=document.getElementsByClassName("container")[0]; var domWrap =document.getElementsByClassName("print_wrap")[0]; var width = dom.offsetWidth; //获取dom 宽度 var height = dom.offsetHeight; //获取dom 高度 var offsetTop = dom.offsetTop; var scaleBy =1; var canvas =document.createElement('canvas'); canvas.width = width * scaleBy; //定义canvas 宽度 * 缩放 canvas.height = (height + offsetTop) * scaleBy; //定义canvas(高度 +偏移量 )*缩放 canvas.style.width =width * scaleBy + 'px'; canvas.style.height =(height + offsetTop) * scaleBy + 'px'; var context =canvas.getContext('2d'); context.scale(scaleBy, scaleBy); var filename =(new Date()).getTime() + '.' + "png"; html2canvas(dom, { background:"#ffffff", canvas: canvas, useCORS: true, scale: 1, width: width, height: height }).then(function(canvas){ var type ='png'; var imgData =canvas.toDataURL(type); var _fixType =function(type) { type =type.toLowerCase().replace(/jpg/i, 'jpeg'); var r =type.match(/png|jpeg|bmp|gif/)[0]; return 'images/' + r; }; imgData =imgData.replace(_fixType(type),'image/octet-stream'); var saveFile =function(data, filename){ var save_link =document.createElementNS('http://www.w3.org/1999/xhtml', 'a'); save_link.href =data; save_link.download =filename; var event =document.createEvent('MouseEvents'); event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null); save_link.dispatchEvent(event); }; saveFile(imgData,filename); }) }
效果图
原文地址:https://www.cnblogs.com/srqsl/p/15205071.html
- Reporting Service报表开发
- 不要信任云:这不只是安全的问题
- C#温故而知新—闲话.Net
- c# IO&&线程 打造 定时打开指定程序
- 前FDIC主席:比特币政策不应打击加密货币发展
- 任何人都不应该控制区块链供应链
- c# IO操作(带进度的文件复制器,读取文本文件的指定行)
- 高科技来了!玩游戏一样开船的时代来了……
- C++库大全
- 人工智能行业前景预测 全球市场或超2700亿元
- Arxiv网络科学论文摘要14篇
- 工信部:网络强国建设2018年重点工作任务
- 刚刚!张小龙再出重磅!微信小程序掀起新零售红利狂潮!
- 无人驾驶系列——深度学习笔记:Tensorflow的安装-windows系统
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- tp5框架使用cookie加密算法实现登录功能示例
- python实现停车管理系统
- 浅谈Pycharm调用同级目录下的py脚本bug
- Python中logging.NullHandler 的使用教程
- Python中利用aiohttp制作异步爬虫及简单应用
- Linux内核设备驱动之系统调用笔记整理
- python3实现名片管理系统
- Linux IO多路复用之epoll网络编程
- 浅谈python在提示符下使用open打开文件失败的原因及解决方法
- Linux内核设备驱动之内核的调试技术笔记整理
- Python检查和同步本地时间(北京时间)的实现方法
- thinkPHP5.1框架使用SemanticUI实现分页功能示例
- python实现名片管理系统
- Python unittest 简单实现参数化的方法
- CentOS7部署Flask(Apache、mod_wsgi、Python36、venv)