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

相关推荐
晴天丨几秒前
Vue 3项目架构设计:从2200行单文件到24个组件
前端·vue.js
blanks20201 分钟前
为 Zed 编辑器 添加 flutter dart snippets
前端·flutter
Ruihong2 分钟前
你的 Vue 3 defineAsyncComponent(),VuReact 会编译成什么样的 React?
vue.js·react.js·面试
Ruihong6 分钟前
你的 Vue 路由,VuReact 会编译成什么样的 React 路由?
vue.js·react.js·面试
Hello--_--World7 分钟前
Js面试题目录表
开发语言·javascript·ecmascript
慧一居士8 分钟前
Vue中的 h 作用和使用方法介绍
前端·vue.js
晴天丨9 分钟前
Element Plus 组件库实战技巧与踩坑记录
前端·vue.js
胡志辉10 分钟前
m3u8 视频怎么下载?为什么 B 站只给你一个 blob:把 HLS、DASH、MSE 这条前端链路讲透
前端
yhole42 分钟前
SpringBoot + vue 管理系统
vue.js·spring boot·后端
落魄江湖行44 分钟前
进阶篇五 Nuxt4 部署方案:从开发到生产
前端·vue.js·typescript·nuxt4