位置: IT常识 - 正文

dom-to-image(dom-to-image原理)

编辑:rootadmin
dom-to-image 前言

推荐整理分享dom-to-image(dom-to-image原理),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:dom-to-image生成的图片存储在哪里,dom-to-image请求完,再执行下一步,dom-to-image 图片跨域,dom-to-image不清晰,dom-to-image不清晰,dom-to-image滚动区域截图,dom-to-image 图片跨域,dom-to-image 图片跨域,内容如对您有帮助,希望把文章链接给更多的朋友!

之前的文章:vue基于html2canvas和jspdf 生成pdf 、解决jspdf中文乱码问题 简单介绍了html2canvas的基本使用,html2canvas 只能截取可视区域,对于含有滚动条的无法完全截取。后来发现还有一个dom-to-image的库可以支持,并且能够生成svg、png、jpeg 3种格式,当然缺点是不支持safari,并且手机端上兼容性不好。

官方文档 ,不得不说有些库是真恶心,起个差不多的名字,找了半天才找到

安装npm install dom-to-imageimport domtoimage from 'dom-to-image';主要方法和属性

方法:

domtoimage.toPng(…);将节点转化为png格式的图片domtoimage.toJpeg(…);将节点转化为jpg格式的图片domtoimage.toSvg(…);将节点转化为svg格式的图片,生成的图片的格式都是base64格式domtoimage.toBlob(…);将节点转化为二进制格式,这个可以直接将图片下载domtoimage.toPixelData(…);获取原始像素值,以Uint8Array 数组的形式返回,每4个数组元素表示一个像素点,即rgba值。这个方法也是挺实用的,可以用于WebGL中编写着色器颜色。

属性:

filter : 过滤器节点中默写不需要的节点;bgcolor : 图片背景颜色;height, width : 图片宽高;style :传入节点的样式,可以是任何有效的样式;quality : 图片的质量,也就是清晰度;一个介于 0 和 1 之间的数字,表示 JPEG 图像的图像质量(例如 0.92 => 92%)。默认为 1.0 (100%)cacheBust : 将时间戳加入到图片的url中,相当于添加新的图片;imagePlaceholder : 图片生成失败时,在图片上面的提示,相当于img标签的alt;使用png<template> <div> <div style="padding:50px;width:500px;border:1px solid red;" id="test"> <p>我是p标签</p> <h1>我是h1标签</h1> <div>我是div标签</div> <img src="./11.jpg" style="width:200px;" /> </div> <el-button type="primary" @click="createImage">生成图片</el-button> <div style="width:500px;height:200px;margin-top:20px;border:1px solid red;"> <p>生成的图片</p> <img :src="dataUrl" style="width:200px;" /> </div> </div></template><script>import domtoimage from 'dom-to-image'export default { data() { return { dataUrl: '' } }, methods: { createImage() { let node = document.getElementById('test'); let that = this domtoimage.toPng(node) .then(function (dataUrl) { //console.log(dataUrl) that.dataUrl = dataUrl }) .catch(function (error) { console.error('生成失败', error); }); } }}</script>dom-to-image(dom-to-image原理)

效果

其他格式

代码同png,用对应的方法即可

属性

filter

createImage() { let node = document.getElementById('test'); let that = this domtoimage.toPng(node, { filter: that.filterTag }) .then(function (dataUrl) { console.log(dataUrl) that.dataUrl = dataUrl }) .catch(function (error) { console.error('生成失败', error); });},filterTag(node) { console.log(node, node.tagName) return node.tagName == 'IMG'}

注意:先打印一下标签名,一开始以为图片就是img结果是IMG

bgcolor

domtoimage.toPng(node, { bgcolor: '#ddd' }) .then(function (dataUrl) { console.log(dataUrl) that.dataUrl = dataUrl // FileSaver.saveAs(dataUrl, 'a.png'); }) .catch(function (error) { console.error('生成失败', error); });

其他略,没有尝试

下载图片

需要借助:file-saver,基本使用见:FileSaver.js的简单使用

示例:

<template> <div> <div style="padding:50px;width:500px;border:1px solid red;" id="test"> <p>我是p标签</p> <h1>我是h1标签</h1> <div>我是div标签</div> <img src="./11.jpg" style="width:200px;" /> </div> <el-button type="primary" @click="createImage">生成图片</el-button> <div style="width:500px;height:200px;margin-top:20px;border:1px solid red;"> <p>生成的图片</p> <img :src="dataUrl" style="width:200px;" /> </div> </div></template><script>import domtoimage from 'dom-to-image'import FileSaver from 'file-saver';export default { data() { return { dataUrl: '' } }, methods: { createImage() { let node = document.getElementById('test'); let that = this domtoimage.toPng(node) .then(function (dataUrl) { console.log(dataUrl) that.dataUrl = dataUrl FileSaver.saveAs(dataUrl, 'a.png'); }) .catch(function (error) { console.error('生成失败', error); }); }, }}</script>
本文链接地址:https://www.jiuchutong.com/zhishi/295866.html 转载请保留说明!

上一篇:卡鲁拉国家公园里的小湖,爱沙尼亚 (© Sven Zacek/Minden Pictures)(卡拉公路)

下一篇:在Vue 3中使用useStorage轻松实现localStorage功能(vue中的use)

  • 印花税减免税优惠政策202
  • 甲方应项目具备开工条件
  • 小规模企业现金流量表
  • 500以下的收据可以入账吗
  • 贸易公司经营范围有限制吗
  • 出差补贴需要交税
  • 工商年报最迟什么时候申报
  • 股份公司要实缴
  • 非正常户发票管理
  • 出纳人员应该怎么称呼
  • 应付账款不用付了摘要怎么写
  • 债务豁免的会计分录
  • 哪些业务需要编写收款凭证
  • 非独立核算分公司怎么报税
  • 发票过期未认证可以用吗
  • 收到加盟费尾款怎么做分录?
  • 银行承兑汇票开票流程图
  • 不应该计入管理费用的
  • 增值税普通发票税率
  • 二手车过户员怎么样
  • 继续教育专项附加扣除标准
  • 个人非货币性资产投资个人所得税
  • 附有销售退回条款的递延所得税问题
  • won11检测
  • 所得税补税怎么申报
  • 超市的成功秘诀
  • 账务和申报表不一致
  • Win11截图工具怎么设置快捷键
  • php魔术方法的讲解与使用
  • 发票作废的政策规定
  • web服务器做什么用的
  • 无偿接收股权
  • 报销凭证写错了怎么办
  • Access-Control-Expose-Headers 响应报头、跨域 公开响应头
  • Yii2表单事件之Ajax提交实现方法
  • 车间装修预算表
  • midjourney 初级使用说明
  • 城建税退回与不退税区别
  • 厂房没租出去要交税吗
  • 自然人三方协议支付宝怎么处理
  • 结转成本的会计科目
  • phpcms目录结构
  • mysql 小时差
  • 防伪税款服务费抵扣
  • 有净残值的固定资产累计折旧怎么算
  • 公司与公司的往来款计入什么科目
  • 个体户没有税务登记怎么开发票
  • 领用库存商品用于生产产品
  • 公司注销固定资产必须清理吗
  • 采购入库单如何弃审U8
  • 出租不动产如何缴纳增值税
  • 专票错误已认证需要退回吗?
  • 完工结转的会计分录
  • 招标代理服务费计算器在线
  • 企业对处于不同位置的产品或服务制定不同的价格
  • 收到分公司负责人的礼物
  • sqlyog存储过程
  • windows server 2008 64位MySQL5.6免安装版本配置方法图解
  • MySQL使用xtrabackup进行备份还原操作
  • 远程登陆服务器命令
  • 应用商店windows
  • win10收不到20h2更新
  • searchnav.exe - searchnav是什么进程 有什么用
  • win8显示屏亮度调节
  • po|iceofficer是什么意思
  • win102021年1月大更新
  • (1)cocos2d-x-2.2.4搭建windows开发环境
  • node. js教程
  • python 列表分片
  • python提供三种基本数值类型
  • 老生常谈的近义词
  • Unity3d C# Socket 下载文件 (同步向)
  • android 高德地图收费
  • javascript函数
  • 房屋维修基金会计分录处理
  • 税务局2017年40号令
  • 点击正式申报前怎么操作
  • 国家税务总局郴州
  • 四川省人口数据资料
  • 怎么申请企业信用修复
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设