当前位置: 首页 > news >正文

商城后台管理系统 02, Vue项目-下载图片资源

html2canvas 官网: http://html2canvas.hertzen.com/

首先关于canvas,可以看看官网https://www.canvasapi.cn/HTMLCanvasElement/,

canvasjs图标库的官网:https://canvasjs.com/jquery-charts/

canvas官网

https://developer.mozilla.org/zh-CN/docs/Web/API/Canvas_API https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLCanvasElement/toDataURL HTMLCanvasElement.toDataURL() 方法返回一个包含图片表示的 data URI,此图片的格式由 type 参数指定。 可以指定所需的文件格式和图片质量。如果未指定文件格式,或指定的文件格式不受支持,则数据将以 image/png 导出。换句话说,如果传入的类型非 image/png,但是返回的值以 data:image/png 开头,那么这个类型是不受支持的。 浏览器被要求支持 image/png,许多浏览器也会支持 image/jpeg 和 image/webp 在内的其他格式。 对于支持编码分辨率元数据的文件格式,创建的图像数据将具有 96dpi 的分辨率。
Vue项目-下载图片资源 实现代码如下
1, src/views/User/index.js <template> <div class="user"> <div class="hetong"> <!-- 1, 查看合同 --> 签约合同内容:<el-button type="primary" size="small" @click="look">查看合同</el-button> </div> <VuePdf ref="myPdf" /> <!-- 2, 查看发票 --> <div class="money"> <el-row :gutter="20"> <el-col :span="8"> <el-card class="box-card"> <div slot="header" class="clearfix"> <span>卡片名称</span> <el-button @click="download" style="float: right; padding: 3px 0;" type=" text">下载发票</el-button> </div> <div class="text item"> <img ref="img" style="width: 400px;" :src="imgUrl" alt="" /> </div> </el-card> </el-col> <el-col :span="8"> <el-card class="box-card"> <div slot="header" class="clearfix"> <span>卡片名称</span> <el-button @click="downs" style="float: right; padding: 3px 0;" type=" text">下载不同源发票</el-button> </div> <div class="text item"> <img ref="myimg" style="width: 400px;" src="../../assets/images/88.png" alt="" /> </div> </el-card> </el-col> <el-col :span="8"> <el-card class="box-card"> <div slot="header" class="clearfix"> <span>卡片名称</span> <el-button @click="down()" style="float: right; padding: 3px 0;" type=" text">下载本地发票</el-button> </div> <div class="text item"> <img ref="img" style="width: 400px;" :src="imgUrl" alt="" /> </div> </el-card> </el-col> </el-row> </div> </div> </template> <script> import VuePdf from '@/views/User/VuePdf'; import img from '@/assets/images/88.png'; export default { data() { return { imgUrl: img, }; }, components: { VuePdf }, methods: { // 查看合同 look() { this.$refs.myPdf.dialogVisible = true }, download() { // 1, 新窗口打开网址 右键保存 look() open() let url = this.$refs.img; console.log(url.src); window.location.href = url.src; }, // 2, 必须同源才能下载 可以直接下载 down() { var alink = document.createElement("a"); alink.href = this.imgUrl; console.log(this.imgUrl); alink.download = "pic"; // 图片名 alink.click(); }, // 解决图片不同源下载问题 downloadImage(imgsrc, name) { // 下载图片地址和图片名 创建图片 var image = new Image(); // <img /> // 解决跨域 canvas 污染问题 image.setAttribute("crossOrigin", "anonymous"); // 读图片 image.onload = function() { var canvas = document.createElement("canvas"); canvas.width = image.width; canvas.height = image.height; var context = canvas.getContext("2d"); context.drawImage(image, 0, 0, image.width, image.height); // 得到图片的 base64 编码数据 图片格式 默认为 image/png var url = canvas.toDataURL("image/png"); // 生成一个 a 元素 var a = document.createElement("a"); // 创建一个单击事件 var event = new MouseEvent("click"); // 设置图片名称 a.download = name || "photo"; // 将生成的URL设置为a.href属性 a.href = url; // 触发a的单击事件 a.dispatchEvent(event); }; // 给图片赋值 image.src = imgsrc; }, downs() { this.downloadImage(this.$refs.myimg.src, "pic"); }, }, }; </script> <style lang="less" scoped> .user { margin: 10px; } </style>

http://www.cnnetsun.cn/news/79465.html

相关文章:

  • spark的统一内存管理机制
  • 终极方案:巧用PVC与StorageClass彻底解决Hadoop在K8s的存储难题
  • 8、算法与数据结构实用案例解析
  • palera1n越狱终极指南:从零开始解锁iOS设备完整教程
  • GLM-4-32B-0414:重塑智能体技术栈的推理引擎革命
  • 终极色彩生成器:一键打造完美配色方案
  • Blender版本管理技巧:从新手到高手的全流程指南
  • F5-TTS移动端部署终极指南:5大技巧实现70%内存优化与性能飞跃
  • DataX Web UI:企业数据同步的终极可视化解决方案
  • 系统可观测性实战指南:从混乱日志到智能洞察的架构进化
  • 分布式训练终极指南:同步与异步策略深度解析
  • 一根同轴线,真的扛得住 4K 吗? ——从摄像头带宽算起,聊透车载 SerDes 接口选型
  • 掌握质谱分析:OpenMS完整使用指南与实战技巧
  • CloudStream智能文件管理:告别杂乱无章的媒体库
  • CopyQ剪贴板管理终极指南:3个核心技巧打造高效工作流
  • Linly-Talker数字人系统对网络带宽的要求分析
  • ExoPlayer状态恢复:如何让视频播放器记住你的“续播点“?
  • MSBuild BuildCheck框架:构建质量革命与团队效率提升终极指南
  • Wechaty智能消息处理全攻略:告别单一回复,实现多场景精准响应
  • Langchain-Chatchat在企业知识管理中的5大应用场景
  • Arkime性能监控完整教程:构建企业级流量分析平台
  • 秒开体验:SmartTube视频缩略图加载与缓存优化实战
  • 20、GNU Make标准库函数详解
  • 21、GNU Make 标准库实用功能与使用技巧详解
  • HyperLPR3实战指南:快速搭建高精度车牌识别系统
  • 当AI患上“健忘症“:MemGPT如何用AWS Bedrock Claude打造过目不忘的智能助手
  • SmartTube视频缩略图优化:3大策略让加载速度提升5倍
  • Excalidraw GitHub Actions工作流配置示例
  • COCO 2017 数据集完整下载指南:百度网盘高速通道
  • 6、文件操作全攻略