需求
打开office文件后,可以实现区域截屏,并且记住当前截屏位置的文档页码
![](https://img.haomeiwen.com/i13136520/561c84140933fb64.png)
业务场景
这边office文件用的officeweb365打开的,打开方式是officeweb365那边的方法
![](https://img.haomeiwen.com/i13136520/45e156752f01de8c.png)
实现思路
1 需要把网页转化为canvas,借用了html2canvas
2 需要记住区域框的位置信息,利用drawImage方法实现区域截屏
3 生成截屏到oss
html2canvas使用方法
基本语法
html2canvas(element, options)
element: html的dom元素,options为参数配置项
![](https://img.haomeiwen.com/i13136520/4bb69bbd7f8b7cc1.png)
实现过程中遇到的问题
1 因为文件是用officeweb365打开的,在获取iframe dom元素的时候,会报一个跨域的问题
![](https://img.haomeiwen.com/i13136520/b3ae8d3becc4be33.png)
因为有个服务器专门部署了预览officeweb365的配置服务,于是想我在这个服务器下写个静态页面,然后跟我这边的业务代码进行交互(跨域问题成功解决了)
![](https://img.haomeiwen.com/i13136520/0460f2cf65c906de.png)
既然是写在两个项目中的代码,就牵扯到数据之间的相互传递了,先买个关子,后面代码中会提到
2 因为要实现再打开的时候,记住截屏的页面,问了officeweb365那边,展示不支持这个方法,于是想到了用pdf.js,恰巧officeweb365有个可以把所有文件都转化成pdf文件的功能
![](https://img.haomeiwen.com/i13136520/0e3c0a8145f691a3.png)
自己的业务代码.previewDialog
html部分
![](https://img.haomeiwen.com/i13136520/b2c5b4842e74c911.png)
js部分
![](https://img.haomeiwen.com/i13136520/3d05d80e1bd243b2.png)
officeweb365服务器上静态页面代码
html部分
<div class='preview-content'>
<iframe id="iframe01" class='iframeBox' :src='openUrl' style="border: 0;" height="100%" width="100%"
scrolling="auto" sandbox="allow-same-origin allow-scripts allow-popups allow-forms">
</iframe>
</div>
js部分
技术难点: 因为要记住页码,所有实现截屏也是在某一页的基础上进行截屏,所有首先要定位当前打开pdf文件在第几页
pdf.js 打开文档拼接地址
![](https://img.haomeiwen.com/i13136520/540c66b3e02a090a.png)
获取打开pdf在第几页
发现利用pdf.js打开文件的时候,会在localStorage里面存储页面信息
![](https://img.haomeiwen.com/i13136520/4c2a7bf04dcc659c.png)
pageNumber = history.files[0].page // 获取当前页码
获取当前页码的dom元素转化为canvas
![](https://img.haomeiwen.com/i13136520/4609d1f8713168e7.png)
业务代码截屏功能实现
html
![](https://img.haomeiwen.com/i13136520/f82adecb2ffb10bf.png)
接收刚刚传过来的参数
![](https://img.haomeiwen.com/i13136520/bdc4dc7c1a95466c.png)
实现效果
开始截屏
![](https://img.haomeiwen.com/i13136520/af2501f02e65ed63.png)
![](https://img.haomeiwen.com/i13136520/ba0be38856420197.png)
![](https://img.haomeiwen.com/i13136520/a94149ca47d3d66b.png)
![](https://img.haomeiwen.com/i13136520/57a53c8137d84fd6.png)
网友评论