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

相关推荐
烛阴24 分钟前
从零开始掌握C#核心:变量与数据类型
前端·c#
han_29 分钟前
前端高频面试题之Vuex篇
前端·vue.js·面试
qq_415216251 小时前
vue3搭建项目yarn+vue3+webpack+less+element-plus
前端·webpack·less
天天向上10241 小时前
VueUse的使用
前端·vue.js·vscode
FREE技术1 小时前
学生成绩管理系统 基于java+springboot+vue实现前后端分离项目并附带万字文档(源码+数据库+万字详设文档+软件包+安装教程)
java·vue.js·spring boot·mysql
猪猪拆迁队2 小时前
前端图形引擎架构设计:双引擎架构设计
前端·后端·架构
宋辰月3 小时前
学习react第三天
前端·学习·react.js
bug总结3 小时前
更新原生小程序封装(新增缓存订阅)完美解决
前端·缓存·小程序
GISer_Jing3 小时前
Node.js 开发实战:从入门到精通
javascript·后端·node.js
5335ld3 小时前
后端给的post 方法但是要求传表单数据格式(没有{})
开发语言·前端·javascript·vue.js·ecmascript