vue html2canvas 将html转图片时遇到的问题解决

问题1:

场景为将富文本组件tinymce里的html内容转为图片,出现的问题是vue获取不到tinymce元素,无法直接使用html2canvas

解决1:

将富文本内容渲染出来,推荐做法是将提交按钮改为预览按钮,然后在另外的弹框中渲染出富文本内容,如图formData.details是富文本中的内容

html 复制代码
<el-button v-if="!showInfo" type="primary" @click="showPreview = true">预 览</el-button>

<el-dialog :visible="showPreview" width="1250px" @close="showPreview = false" >
    <div ref="canvas" v-html="formData.details"></div>
    <div style="text-align: center">
         <el-button @click="showPreview = false">返 回</el-button>
         <el-button v-if="!showInfo" type="primary" @click="handleSubmit">提 交</el-button>
     </div>
</el-dialog>

问题2:

将富文本的html转为图片后,富文本中的图片缺失(主要是跨域引起)

解决2:

  1. 富文本中的img标签中增加属性 crossOrigin="anonymous";经测试,没有该属性也是可以的

  2. html2canvas增加配置useCORS:true;

  3. 后端跨域配置;

javascript 复制代码
async htmlToImage(){
   const element = this.$refs.canvas
   var _html2canvas = await html2canvas(element, { useCORS: true })
   this.formData.base64 = _html2canvas.toDataURL('image/png')
   console.log(this.formData.base64)
},

注意:VUE记得安装html2canvas,npm install html2canvas -save

相关推荐
老前端的功夫几秒前
TypeScript 类型守卫:从编译原理到高级模式
前端·javascript·架构·typescript
未来之窗软件服务11 分钟前
幽冥大陆(七十二) 东方仙盟-在线IP归属地自己封装—东方仙盟练气期
前端·javascript·tcp/ip·仙盟创梦ide·东方仙盟·阿雪技术观
QT 小鲜肉25 分钟前
【Linux命令大全】001.文件管理之mc命令(实操篇)
linux·运维·服务器·前端·笔记
ttod_qzstudio30 分钟前
备忘录之事件监听器绑定陷阱:为什么 .bind(this) 会移除失败?
javascript·typescript·内存泄漏·事件监听
土豆_potato32 分钟前
AI深度思考到底开不开
前端·aigc
ohyeah32 分钟前
React 中的跨层级通信:使用 Context 实现主题切换功能
前端·react.js
winfredzhang1 小时前
打造专属桌面时钟:纯HTML实现的全功能动态时钟
前端·html·农历·生肖·周次
哥本哈士奇1 小时前
使用Gradio构建AI前端 - RAG的QA模块
前端·人工智能·状态模式
扶我起来还能学_1 小时前
Vue3 proxy 数据响应式的简单实现
前端·javascript·vue
Dragon Wu2 小时前
前端项目架构 项目格式化规范篇
前端·javascript·react.js·前端框架