html生成缩略图来预览解决方案
html生成缩略图来预览解决方案
一、总结
一句话总结:先将html转化为canvas,然后将canvas生成图片ajax上传到服务器,就可以了
html 转化 canvas 图片 上传 html2canvas.js
1、如何将html转化为canvas?
SVG foreignObject元素
html2canvas.js
首先我们不能直接把 HTML 画到 canvas 上。我们需要使用一个SVG 图像包含想要呈现的内容 。为了绘制 HTML 内容,你要先用<foreignObject>
元素包含 HTML 内容,然后再将这个 SVG 图像绘制到你的 canvas 中。
这里的foreignObject
元素允许包含外来的XML命名空间,其图形内容是别的用户代理绘制的。这个被包含的外来图形内容服从SVG变形和合成。
我们转化的步骤为:
1. 创建一个blob 对象, 其 MIME 应为 “image/svg+xml”。
2. 一个 <svg>
元素。
3. 在 SVG 元素中包含的 <foreignObject>
元素。
4. 包裹到 <foreignObject>
中的(格式化好的) HTML。
也可以直接用框架,效果更好。html2canvas.js。
2、canvas转化为图片的框架?
Canvas2Image.js
其实你想实现什么效果,比如canvas转化为图片的js,直接google百度上面一搜就好,一大堆
二、HTML如何转化为canvas教程
预览图
老规矩, 先放图
第一个红格子是DOM渲染的, 第二个带边框的红格子是用html的代码在canvas画出来的, 没有使用canvas的api哦. 本文最后贴出了代码.
原理
本文转化的实现, 以及本文下半部分所介绍的html2canvas.js框架的原理均出自于, mdn的这个篇文章将 DOM 对象绘制到 canvas 中
首先我们不能直接把 HTML 画到 canvas 上。我们需要使用一个SVG 图像包含想要呈现的内容 。为了绘制 HTML 内容,你要先用<foreignObject>
元素包含 HTML 内容,然后再将这个 SVG 图像绘制到你的 canvas 中。
这里的foreignObject
元素允许包含外来的XML命名空间,其图形内容是别的用户代理绘制的。这个被包含的外来图形内容服从SVG变形和合成。
我们转化的步骤为:
1. 创建一个blob 对象, 其 MIME 应为 “image/svg+xml”。
2. 一个 <svg>
元素。
3. 在 SVG 元素中包含的 <foreignObject>
元素。
4. 包裹到 <foreignObject>
中的(格式化好的) HTML。
第一步预览图的代码
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<div class="wrapper">
<div class="target" style="
width: 100px;
height: 100px;
background: red;
margin-bottom: 50px;
">123</div>
</div>
<canvas id="canvas" style="border:2px solid black;" width="200" height="200">
</canvas>
<script>
let canvas = document.getElementById('canvas');
let ctx = canvas.getContext('2d');
let target = document.getElementsByClassName('wrapper');
// 创造svg
let data = `
<svg xmlns="http://www.w3.org/2000/svg" width="200" height="200">
<foreignObject width="100%" height="100%">
<div xmlns="http://www.w3.org/1999/xhtml" style="font-size:40px">
${target[0].innerHTML}
</div>
</foreignObject>
</svg>
`
let DOMURL = window.URL || window.webkitURL || window;
let img = new Image();
let svg = new Blob([data], {type: 'image/svg+xml;charset=utf-8'});
let url = DOMURL.createObjectURL(svg);
// 根据svg生产url
img.onload = function () {
ctx.drawImage(img, 0, 0);
DOMURL.revokeObjectURL(url); // 摧毁刚刚生产的url
}// 注册回调函数
img.src = url;
// 将图片url塞到img里
</script>
</body>
</html>
有几个需要注意的点:
1. 此方法中插入的html必须是有效的html
2. 必须使用内联样式, 并且支持部分样式,
3. 已访问的链接样式(:visited
)不会对 SVG 图像中的链接生效,因此无法获取浏览历史;SVG 图像中也不会渲染原生主题,因此借此检测用户的平台也会更困难。
4. 此外,您也不能在 SVG 图像中各种引入脚本文件,因此不会有从其他脚本文件访问 DOM 的风险。SVG 图像中的 DOM 元素也不能接收事件的输入,因此无法将敏感信息载入到一个表单控件(如将完整路径载入到 file <input>
元素中)渲染再通过读取图像获取这些信息。
5. 这个解决方案所依赖的 SVG 图像在实现上是非常严格
的。如果引入了外部的图片会污染canvas画布. 但是接下来说介绍的html2canvas
可以解决这个问题!!!
html2canvas
框架官网地址: http://html2canvas.hertzen.com/
本文使用介绍基于1.0.0-alpha.12版本
效果图
这次直接有框架生成的canvas, 因此没有了边框. 下面是代码
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.target {
width: 100px;
height: 100px;
background: red;
margin-bottom: 50px;
}
</style>
</head>
<body>
<div class="wrapper">
<div class="target">123</div>
</div>
<script src="./canvas.js"></script>
<script>
window.onload = function() {
html2canvas(document.querySelector(".wrapper")).then(canvas => {
document.body.appendChild(canvas)
});
}
</script>
</body>
</html>
.then
是promise语法, 不了解es6的同学可以看看阮一峰es6入门, 写的非常好.
上面的代码可以看到, 支持内联样式了, 同时使用起来也很简单. 那么上文所留下的悬念: 如何加载外部图片呢? 接下来将会和html2canvas的配置项一起介绍给大家.
html2canvas配置项
名称 | 默认 | 描述 |
---|---|---|
async | true | 是否异步解析和渲染元素 |
allowTaint | false | 是否允许跨原始图像污染画布 |
backgroundColor | ffffff | 画布背景颜色 |
canvas | null | 你自己提供一个canvas用作绘图, 此项不填框架会自动生成一个canvas标签 |
foreignObjectRendering | false | 就是是否用上面所提到的foreignObject这个来渲染, 默认为遍历dom树 |
imageTimeout | 15000 | 设置图像加载的超时时间(以毫秒为单位)设置0为禁用超时 |
ignoreElements | (element) => false | Predicate function which removes the matching elements from the render. 大致的意思是匹配元素, 在你渲染的时候去掉那个匹配的元素 |
logging | true | 启用日志记录以进行调试 |
onclone | null | Callback function which is called when the Document has been cloned for rendering, can be used to modify the contents that will be rendered without affecting the original source document.这个我也不知道是干嘛的, 欢迎大家踊跃提出建议 |
proxy | null | 填写url, 设置代理,用于加载跨源图像. 如果为null,跨域图片则不会加载 |
removeContainer | true | Whether to cleanup the cloned DOM elements html2canvas creates temporarily(还得研究, 不知道那个cloned DOM是干嘛的) |
scale | window.devicePixelRatio | 设置渲染的比例。默认为浏览器设备像素比率 |
useCORS | false | 是否尝试使用CORS从服务器加载图像 |
width | canvas宽度 | |
height | canvas高度 | |
X | Element x偏移量 | |
y | Element y偏移量 |
开启图片跨域
效果图
图片随便在网上找的
代码
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
img {
width: 500px;
}
</style>
</head>
<body>
<div class="wrapper">
<img src="https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1533212152031&di=f26250570f7d5f2e7895c7c13e96d61a&imgtype=0&src=http%3A%2F%2Fh.hiphotos.baidu.com%2Fimage%2Fpic%2Fitem%2F267f9e2f07082838304837cfb499a9014d08f1a0.jpg"></img>
</div>
<script src="./canvas.js"></script>
<script>
window.onload = function() {
html2canvas(document.querySelector(".wrapper"), {
allowTaint: true,
useCORS: true,
}).then(canvas => {
document.body.appendChild(canvas)
});
}
</script>
</body>
</html>
ps: 如果在小瓶图片变糊, 可以试着设置那个scale参数, 或者采用在canvas的width属性设置例如1000, 在css中设置width: 500px; 来进行压缩
如果你需要保存为本地图片可以采用Canvas2Image.js这个框架, 具体内容百度, 本文不做介绍
参考:HTML如何转化为canvas教程 - 翾的博客 - CSDN博客
https://blog.csdn.net/c_kite/article/details/81364592
html生成缩略图来预览解决方案的更多相关文章
- Org mode无法生成LaTeX公式预览图片
最近需要在Cygwin平台下的Emacs Org mode中生成LaTeX数学公式的预览图片,从而得到图文并貌的笔记与任务管理文档.但当我执行org-toggle-latex-fragment命令后却 ...
- Atitit. IE8.0 显示本地图片预览解决方案 img.src=本地图片路径无效的解决方案
Atitit. IE8.0 显示本地图片预览解决方案 img.src=本地图片路径无效的解决方案 1. IE8.0 显示本地图片 img.src=本地图片路径无效的解决方案1 1.1. div来完成 ...
- word文档在线预览解决方案
花了一整天在网上翻关于 “word文档在线预览解决方案” 相关的资料,感觉实现难度比较大还是用PDF来解决好了.. 下面列一下比较好的参考资料吧 参考资料 前端实现在线预览pdf.word.xls.p ...
- SpringBoot-文件在线预览解决方案-基于OpenOffice及jacob
项目中有一个需求:实现文件(主要是Office文件)的在线预览,根据前端需求,Office文件需要转换成pdf或者html方可在浏览器中打开预览,那么后端需要将文件转为pdf/格式返回地址给前端.目前 ...
- WEB文档在线预览解决方案
web页面无法支持预览office文档,但是却可以预览PDF.flash文档,所以大多数解决方案都是在服务端将office文档转换为pdf,然后再通过js的pdf预览插件(谷歌浏览器等已经原生支持嵌入 ...
- markdown2 在win10下无法预览解决方案
今天升级完Win10发现心爱的markdownPad 2无法预览,显示the view has crashed! 按照官网的Q&A http://markdownpad.com/faq.htm ...
- 最好用的js前端框架、组件、文档在线预览插件
这里收集的都是个人认为比较好的js框架.组件 js前端ui框架 此处列举出个人认为最好的几个框架(排序即排名),现在好点的框架商用都需要付费,以下几个也不例外,但是由于组件丰富,都可以作为企业应用的完 ...
- 手把手教你用 Spring Boot搭建一个在线文件预览系统!支持ppt、doc等多种类型文件预览
昨晚搭建环境都花了好一会时间,主要在浪费在了安装 openoffice 这个依赖环境上(Mac 需要手动安装). 然后,又一步一步功能演示,记录,调试项目,并且简单研究了一下核心代码之后才把这篇文章写 ...
- 在线操作word和在线预览查找的资料记录
在线操作word和在线预览查找的资料记录 在线操作word查找的资料记录 富文本操作 http://fex.baidu.com/ueditor/ 控件类 通过 js 调用控件操作 word 文档 1. ...
随机推荐
- VS2010/MFC编程入门之三十四(菜单:VS2010菜单资源详解)
上一节讲了标签控件Tab Control以后,常用控件的内容就全部讲完了,当然并没有包括所有控件,主要是一些很常用很重要的控件.本节开始鸡啄米将为大家讲解菜单的概念及使用. 菜单简介 菜单在界面设计中 ...
- CTC(Connectionist Temporal Classification)介绍
CTC解决什么问题 CTC,Connectionist Temporal Classification,用来解决输入序列和输出序列难以一一对应的问题. 举例来说,在语音识别中,我们希望音频中的音素和翻 ...
- 《Hadoop权威指南》(Hadoop:The Definitive Guide) 气象数据集下载脚本
已过时,无法使用 从网上找到一个脚本,修改了一下 #!/bin/bash CURRENT_DIR=$(cd `dirname $0`; pwd) [ -e $CURRENT_DIR/ncdc ] || ...
- DeepMind已将AlphaGo引入多领域 Al泡沫严重
DeepMind已将AlphaGo引入多领域 Al泡沫严重 在稳操胜券的前提下,谷歌旗下的AlphaGo还是向柯洁下了战书.4月10日,由中国围棋协会.浙江省体育局.谷歌三方联合宣布,将于5月23日至 ...
- P2512 [HAOI2008]糖果传递&&P3156 [CQOI2011]分金币&&P4016 负载平衡问题
P2512 [HAOI2008]糖果传递 第一步,当然是把数据减去平均数,然后我们可以得出一串正负不等的数列 我们用sum数组存该数列的前缀和.注意sum[ n ]=0 假设为链,那么可以得出答案为a ...
- 关于sqlite使用场景
对于sqlite,实际中从来没有用过,也几乎没有考虑过其使用场景,更不要说专门去研究它了,今天看最新的数据库流行度排行榜的时候,发现sqlite的长期趋势好像一直在第十位左右徘徊,特地搜索了下其使用场 ...
- [矩阵十题第七题]vijos 1067 Warcraft III 守望者的烦恼 -矩阵快速幂
背景 守望者-warden,长期在暗夜精灵的的首都艾萨琳内担任视察监狱的任务,监狱是成长条行的,守望者warden拥有一个技能名叫“闪烁”,这个技能可以把她传送到后面的监狱内查看,她比较懒,一般不查看 ...
- Linux内核同步机制--自旋锁【转】
本文转载自:http://www.cppblog.com/aaxron/archive/2013/04/12/199386.html 自旋锁与互斥锁有点类似,只是自旋锁不会引起调用者睡眠,如果自旋锁已 ...
- 【分布式计算】30分钟概览Spark分布式计算引擎
本文主要帮助初学者快速了解Spark,不会面面俱到,但核心一定点到. Spark是继Hadoop之后的下一代分布式内存计算引擎,于2009年诞生于加州大学伯克利分校AMPLab实验室,现在主要由Dat ...
- 51nod 1083 矩阵取数问题
就很简单很简单的dp 只能从右或者从下走 所以 dp方程直接看下面公式吧 反正也不难 #include<bits/stdc++.h> using namespace std; ; in ...