百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

超不错 Vue.js 实现H5页面截图

ztj100 2024-12-03 06:54 35 浏览 0 评论

在开发vue项目,有时会遇到需要页面截图或指定区域截图需求。今天给大家推荐2个超赞的截图插件。

1、html2canvas

一款超强大的Javascript页面截图类库,star高达21.4K+。支持h5页面截图、区域截图及跨域截图等功能。

下面讲一下如何在vue中使用html2canvas截图。

安装

$ npm i html2canvas -S

使用组件

<template>
  <div class="shot-wrapper">
    <!-- 要截图的区域,动态生成 -->
    <div class="shot-area" id="content" ref="imageToFile"></div>
    
    <!-- 截图生成图片 -->   
    <img :src="img" v-if="img"/>
    
    <button type="button" class="shot-btn" @click="screenShot">开始截图</button>
  </div>
</template>
<script>
  import html2canvas from 'html2canvas'
  export default {
    data() {
      return {
        img: ""
      }
    },
    methods: {
      screenShot() {
        html2canvas(this.$refs.imageToFile, {
          width: window.innerWidth || document.documentElement.clientWidth || document.body.clientWidth,
          height: window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight,
        }).then((canvas) => {// 第一个参数是需要生成截图的元素,第二个是自己需要配置的参数,宽高等
          this.img = canvas.toDataURL('image/png');
        })
      },
    },
    components: {
      html2canvas
    }
  }
</script>

如果大家想要了解更多用法,可以自行去官网查阅资料哈~~

# 文档地址
http://html2canvas.hertzen.com/

# 仓库地址
https://github.com/niklasvh/html2canvas

2、Dom-To-Image

一款超不错的将任意DOM节点转换为用JavaScript编写的矢量(SVG)或光栅(PNG或JPEG)图像的库。star高达6.4K+

下面介绍下在vue中如何使用domtoimage进行截图。

安装

$ npm i dom-to-image -S

使用组件

<template>
  <div class="domtoimage-wrapper">
    <!-- 要截图的区域,动态生成 -->
    <div class="dom-area" id="my-node"></div>
    
    <!-- 截图生成图片 -->   
    <img :src="img" v-if="img"/>
    
    <button type="button" class="shot-btn" @click="shotPic">开始截图</button>
  </div>
</template>

<script>
  import domtoimage from 'dom-to-image'
  export default {
    data() {
      return {
        img: ""
      }
    },
    methods: {
      shotPic() {
        let node = document.getElementById('my-node');
        domtoimage.toPng(node)
          .then((dataUrl) => {
            this.img = dataUrl;
          })
          .catch(function (error) {
            console.error('oops, something went wrong!', error);
          });
      }
    },
    components: {
      domtoimage
    }
  }
</script>

domtoimage主要的属性

  • filter:过滤器节点中默写不需要的节点;
  • bgcolor:图片背景颜色;
  • height,width:图片宽高;
  • style:传入节点的样式,可以是任何有效的样式;
  • quality:图片的质量,也就是清晰度;
  • cacheBust:将时间戳加入到图片的url中,相当于添加新的图片;
  • imagePlaceholder:图片生成失败时,在图片上面的提示,相当于img标签的alt;

domtoimage主要的方法

  • domtoimage.toPng(...); 将节点转化为png格式的图片;
  • domtoimage.toJpeg(...); 将节点转化为jpg格式的图片;
  • domtoimage.toSvg(...); 将节点转化为svg格式的图片,生成的图片的格式都是base64格式;
  • domtoimage.toBlob(...); 将节点转化为二进制格式,这个可以直接将图片下载;
  • domtoimage.toPixelData(...); 获取原始像素值,以Uint8Array 数组的形式返回;

最后附上项目地址,可以去了解更多信息。

# 仓库地址
https://github.com/tsayen/dom-to-image

ok,就介绍到这里。如果大家有其它优秀的Vue截图组件,欢迎分享交流!

相关推荐

电脑装系统用GHOST好,还是原装版本好?老司机都是这么装的

Hello大家好,我是兼容机之家的咖啡。安装Windows系统是原版ISO好还是ghost好呢?针对这个的问题,我们先来科普一下什么是ghost系统,和原版ISO镜像两者之间有哪些优缺点。如果是很了解...

苹果 iOS 14.5.1/iPadOS 14.5.1 正式版发布

IT之家5月4日消息今日凌晨,苹果发布了iOS14.5.1与iPadOS14.5.1正式版更新。这一更新距iOS14.5正式版发布过去了一周时间。IT之家了解到,苹果表示,...

iOS 13.1.3 正式版发布 包含错误修复和改进

苹果今天发布了iOS13.1.3和iPadOS13.1.3,这是iOS13发布之后第四个升级补丁。iOS13.1.2两周前发布。iOS13.1.3主要包括针对iPad和...

还不理解 Error 和 Exception 吗,看这篇就够了

在Java中的基本理念是结构不佳的代码不能运行,发现错误的理想时期是在编译期间,因为你不用运行程序,只是凭借着对Java基本理念的理解就能发现问题。但是编译期并不能找出所有的问题,有一些N...

Linux 开发人员发现了导致 MacBook“无法启动”的 macOS 错误

“多个严重”错误影响配备ProMotion显示屏的MacBookPro。...

启动系统时无法正常启动提示\windows\system32\winload.efi

启动系统时无法正常启动提示\windows\system32\winload.efi。该怎么解决?  最近有用户遇到了开机遇到的问题,是Windows未能启动。原因可能是最近更改了硬件或软件。虽然提...

离线部署之两种构建Ragflow镜像的方式,dify同理

在实际项目交付过程中,经常遇到要离线部署的问题,生产服务器无法连接外网,这时就需要先构建好ragflow镜像,然后再拷到U盘或刻盘,下面介绍两种构建ragflow镜像的方式。性能测试(网络情况好的情况...

Go语言 error 类型详解(go语言 异常)

Go语言的error类型是用于处理程序运行中错误情况的核心机制。它通过显式的返回值(而非异常抛出)来管理错误,强调代码的可控性和清晰性。以下是详细说明及示例:一、error类型的基本概念内置接口...

Mac上“闪烁的问号”错误提示如何修复?

现在Mac电脑的用户越来越多,Mac电脑在使用过程中也会出现系统故障。当苹果电脑无法找到系统软件时,Mac会给出一个“闪烁的问号”的标志。很多用户受到过闪烁问号这一常见的错误提示的影响,如何解决这个问...

python散装笔记——177 sys 模块(python sys模块详解)

sys模块提供了访问程序运行时环境的函数和值,例如命令行参数...

30天自制操作系统:第一天(30天自制操作系统电子书)

因为咱们的目的是为了研究操作系统的组成,所以直接从系统启动的第二阶段的主引导记录开始。前提是将编译工具放在该文件目录的同级目录下,该工具为日本人川合秀实自制的编译程序,优化过的nasm编译工具。...

五大原因建议您现在不要升级iOS 13或iPadOS

今天苹果放出了iPadOS和iOS13的公测版本,任何对新版功能感兴趣的用户都可以下载安装参与测试。除非你想要率先体验Dark模式,以及使用AppleID来登陆Facebook等服务,那么外媒CN...

Python安装包总报错?这篇解决指南让你告别pip烦恼!

在Python开发中,...

苹果提供了在M1 Mac上修复macOS重装错误的方案

#AppleM1芯片#在苹果新的M1Mac推出后不久,我们看到有报道称,在这些机器上恢复和重新安装macOS,可能会导致安装错误,使你的Mac无法使用。具体来说,错误信息如下:"An...

黑苹果卡代码篇三:常见卡代码问题,满满的干货

前言...

取消回复欢迎 发表评论: