vue 使用 html2canvas 截取图片保存

vue 使用 html2canvas 截取图片保存

好久没有写博文了,写够了,没啥想写的了,这个号算是废了,哎,气人啊!越来越胖,越来越懒了。

html2canvas 简介

html2canvas是一个JavaScript库,它可以将HTML元素转换为Canvas元素。具体来说,它可以将整个页面或特定的HTML元素转换为一幅图像,这对于创建屏幕截图、生成PDF文件或在上创建可编辑的图像非常有用。

html2canvas 安装

安装 html2canvas 很简单,只需要一个简单的命令即可。

npm install html2canvas --save

等待命令执行完成就可以了。

html2canvas 使用

使用的时候也非常的方便。首先在需要使用的地方进行引入。

import html2canvas from 'html2canvas'

在 Vue 组件中使用 html2canvas 将 HTML 元素转换为 canvas:

methods: {  convertToCanvas() {  const element = this.$refs.element // 获取要转换的HTML元素  html2canvas(element).then(canvas => {  // 在这里可以对canvas进行操作,例如将其添加到页面中或保存为图片等  // 例如:this.$refs.canvasContainer.appendChild(canvas)  })  }  
}

在模板中添加要转换的HTML元素和调用方法的引用:

<template>  <div>  <div ref="element">要转换的HTML元素</div>  <button @click="convertToCanvas">转换为Canvas</button>  <div ref="canvasContainer"></div>  </div>  
</template>

当用户点击按钮时,convertToCanvas方法将被调用,它将获取要转换的HTML元素并使用html2canvas将其转换为canvas。转换完成后,可以在then回调函数中对canvas进行操作,例如将其添加到页面中或保存为图片等。

案例:保存缩略图

之前在项目里面写过一个功能,就是把页面保存成缩略图展示。需要获取这个页面的截图,然后把截图数据发送给后端,后端保存起来,然后查询列表的时候后端返回保存的缩略图进行展示。就是引用上面的步骤:

    // 获取截图getPicture() {html2canvas(this.$refs.panelPage).then(canvas => {// 获取生成的图片的url,并设置为png格式const imgUrl = canvas.toDataURL("images/png");let base64Data = imgUrl.split(",")[1];let binaryData = atob(base64Data);let uint8Array = new Uint8Array(binaryData.length);for (let i = 0; i < binaryData.length; i++) {uint8Array[i] = binaryData.charCodeAt(i);}// 获取blob文件流let blob = new Blob([uint8Array], { type: "image/png" });// 文件流转文件let file = new File([blob], "filename.png", {type: "image/png",});let fd = new FormData()fd.append('file', file)// 请求后端数据接口coverUpload(fd) })},

上面获取了截图之后调用请求接口的方法就OK了。

这样就可以把页面的截图获取下来,然后保存缩略图到后端。但是在实际使用上发现一个大问题,就是我引用的网络图片获取截取不下来。于是找了一下原因:是因为跨域的问题导致觉得不安全,就没有截取。

解决这个问题也很简单,配置一下允许跨域,上面代码改一下:

    // 获取截图getPicture(id) {html2canvas(this.$refs.panelPage, {useCORS: true,  // 开启跨域}).then(canvas => {// 获取生成的图片的url,并设置为png格式const imgUrl = canvas.toDataURL("images/png");let base64Data = imgUrl.split(",")[1];let binaryData = atob(base64Data);let uint8Array = new Uint8Array(binaryData.length);for (let i = 0; i < binaryData.length; i++) {uint8Array[i] = binaryData.charCodeAt(i);}// 获取blob文件流let blob = new Blob([uint8Array], { type: "image/png" });// 文件流转文件let file = new File([blob], "filename.png", {type: "image/png",});let fd = new FormData()fd.append('file', file)// 请求后端数据接口coverUpload(id, fd)})},

主要就是这一句代码:useCORS: true

但是发现有些还不行,为啥呢,因为他需要服务端开启跨域 response.setHeader("Access-Control-Allow-Origin","*") ;。如果是自己的服务器的话,那改一下 nginx 的代理配置就可以了。

location /imgSource/ {# 加上这三行就可以了add_header Access-Control-Allow-Origin *;add_header Access-Control-Allow-Headers X-Requested-With;add_header Access-Control-Allow-Methods GET,POST,PUT,DELETE,OPTIONS;autoindex on;alias C:/Users/11466/Desktop/serve/classe/image/;
}

这样就能截取下来了,反正我是成功了。

好了就这样,没啥营养的博文。祝大家工作生活一切顺利!

对了,最近玩 元梦之星 了吗?

在这里插入图片描述

最近中了 元梦之星 的毒,每天晚上玩到很晚,我现在知道什么叫玩物丧志了…

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/298325.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法与数据结构--特殊有序集的线性时间排序算法

一.计数排序算法 基本思想&#xff1a;统计每个输入元素的个数&#xff0c;然后根据这些计数值重构原数组。 使用范围&#xff1a;需要知道元素大小范围&#xff0c;就是最大值是多少。 【排序算法】计数排序_哔哩哔哩_bilibili 二.基数排序 使用场景&#xff1a;只适用于…

策略模式(组件协作模式)

策略模式&#xff08;组件协作模式&#xff09; 策略模式实例代码 注解 目的 正常情况下&#xff0c;一个类/对象中会包含其所有可能会使用的内外方法&#xff0c;但是一般情况下&#xff0c;这些常使用的类都是由不同的父类继承、组合得来的&#xff0c;来实现代码的复用&…

2022第十二届PostgreSQL中国技术大会-核心PPT资料下载

一、峰会简介 本次大会以“突破•进化•共赢 —— 安全可靠&#xff0c;共建与机遇”为主题&#xff0c;助力中国数据库基础软件可掌控、可研究、可发展、可生产&#xff0c;并推动数据库生态的繁荣与发展。大会为数据库从业者、数据库相关企业、数据库行业及整个IT产业带来崭…

【English】水果单词小小汇总~~

废物研究生&#xff0c;只要不搞科研干啥都是开心的&#xff0c;啊啊啊啊啊科研要命。作为一个水果怪&#xff08;每天不吃水果就要命的那种哈哈哈哈&#xff09;突然发现竟然就知道什么apple、banana、orange&#xff01;惭愧惭愧&#xff0c;正好兴致正浓&#xff0c;来整理一…

Redis源码精读:字符串

文章目录 前言代码位置核心类型SDS结构获取sds字符串的元数据的宏获取字符串长度重新设置sds长度创建字符串感悟最后 前言 Redis中实现了sds&#xff08;simple dynamic string&#xff09;这种字符串&#xff0c;它比c语言标准库的char*字符串更加实用 代码位置 src/sdc.h …

Matlab仿真OOK、2FSK、2PSK、QPSK、4QAM在加性高斯白噪声信道中的误码率与归一化信噪比的关系

本文为学习所用&#xff0c;严禁转载。 本文参考链接 https://zhuanlan.zhihu.com/p/667382398 QPSK代码及高斯白噪声如何产生 https://ww2.mathworks.cn/help/signal/ref/butter.html 滤波器 https://www.python100.com/html/4LEF79KQK398.html 低通滤波器 本实验使用matlab仿…

Debezium发布历史20

原文地址&#xff1a; https://debezium.io/blog/2017/09/25/streaming-to-another-database/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. 将数据流式传输到下游数据库 九月 25, 2017 作者&#xff1a; Jiri…

《数字图像处理-OpenCV/Python》连载:图像的阈值处理

《数字图像处理-OpenCV/Python》连载&#xff1a;图像的阈值处理 本书京东 优惠购书链接 https://item.jd.com/14098452.html 本书CSDN 独家连载专栏 https://blog.csdn.net/youcans/category_12418787.html 第 9 章 图像的阈值处理 图像的阈值处理简单、直观&#xff0c;计算…

hash长度扩展攻击

作为一个信息安全的人&#xff0c;打各个学校的CTF比赛是比较重要的&#xff01; 最近一个朋友发了道题目过来&#xff0c;发现有道题目比较有意思&#xff0c;这里跟大家分享下 这串代码的大致意思是&#xff1a; 这段代码首先引入了一个名为"flag.php"的文件&am…

AI 论文精读,中文视频讲解:剖析人工智能本质 | 开源日报 No.120

mli/paper-reading Stars: 21.8k License: Apache-2.0 深度学习论文精读是一个深度学习相关论文列表&#xff0c;包括计算机视觉、生成模型、自然语言处理等多个领域。 该项目的核心优势和特点包括&#xff1a; 提供了大量关于深度学习各领域热门文章内容对不同年份发表的有较…

遍历二叉树的Morris序

参考书&#xff1a;《程序员代码面试指南》 这种方法的好处在于&#xff0c;它做到了时间复杂度为O(n)&#xff0c;额外空间复杂度为O(1)&#xff08;只申请几个变量就可以完成整个二叉树的遍历&#xff09;。 Morris遍历时cur访问节点的顺序就是morris序&#xff0c;可以在M…

61.SVN版本控制系统

SVN&#xff08;Subversion&#xff09;是一种集中式版本控制系统&#xff0c;它有一个中央仓库用于存储代码库的完整历史记录。相对于分布式版本控制系统&#xff08;例如 Git&#xff09;&#xff0c;SVN 不支持本地仓库。 一、SVN 安装。 &#xff08;1&#xff09;在windo…