首页前端开发HTMLhtml2canvas关于图片不能正常截取的解决方案

html2canvas关于图片不能正常截取的解决方案

时间2024-01-26 21:03:02发布访客分类HTML浏览689
导读:收集整理的这篇文章主要介绍了html2canvas关于图片不能正常截取的解决方案,觉得挺不错的,现在分享给大家,也给大家做个参考。 问题首先说说遇到了什么问题。首先有这么一个需求。需要前端根据后端传过来数据,动态的生成图片。图片中...
收集整理的这篇文章主要介绍了html2canvas关于图片不能正常截取的解决方案,觉得挺不错的,现在分享给大家,也给大家做个参考。

问题

首先说说遇到了什么问题。首先有这么一个需求。需要前端根据后端传过来数据,动态的生成图片。图片中的文案、背景图片、用户头像全部都是通过后端的接口获取。但是使用 html2canvas 生成的canvas有些图片成功的在canvas里生成了。但是有些图片无论如何都显示不出来。

官方文档

在项目里面操作了半天未果,GOOGLE了半天未果。此时有些许绝望。突然想到了,为什么不去它的 官网 看看呢。于是乎我在官网上看到了下面的内容。

LimITationsbr/>
All the images that the script uses need to reside under the same origin for it to be able to read them without the assistance of a Proxy. Similarly, if you have other canvas elements on the page, which have been tainted with cross-origin content, they will become dirty and no longer readable by htML2canvas.br/>
The script doesn't render plugin content such as Flash or Java applets.

讲的啥呢,这里为英文不好的同学翻译一下。英语好的可以直接看上文。大概的意思就是在html2canvas里面,是使用脚本去操作的,也就是说使用脚本把html转换成canvas,但是有一个限制,那就是不能使用跨源的图片。如果使用了,html2canvas将不会读取资源。

这也就是为什么转换出来的canvas有些图片一直是空白的原因。如果页面中有其他的canvas也使用了跨源的图片资源,html2canvas都不会去读取。

解决方案

对静态资源做一次转发并且在html2canvas的 配置 里面允许加载跨源资源,就可以了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

html2canvas图片

若转载请注明出处: html2canvas关于图片不能正常截取的解决方案
本文地址: https://pptw.com/jishu/587275.html
html 表格单元格的宽度和高度的设置方法 网页设计关于表单输入框的技巧代码

游客 回复需填写必要信息