Vue H5页面长按保存为图片

安装依赖:npm install html2canvas -d

复制代码
<template>
  <div class="index">
      <div id="captureId" class="capture"   v-show="firstFlag">
        <ul>
          <li>1</li>
          <li>2</li>
          <li>3</li>
        </ul>
        <h2>helloworld</h2>
      </div>
    <img :src="dataURL" alt="" v-show="!firstFlag">
  </div>
</template>
<script>
    import html2canvas from 'html2canvas';
    export default {
        data () {
            return {
                dataURL:'',
                firstFlag:true,
            };
        },
      
        mounted(){
            html2canvas(document.querySelector('#captureId')).then(canvas => {
                let imgUrl = canvas.toDataURL('image/png');
                this.dataURL = imgUrl;
                this.firstFlag = false;
            })
        },
        methods: {

        }
    }
</script>
<style lang='less' scoped>
</style>
  1. <template>标签中定义了组件的模板结构。
  2. captureId是一个具有特定id的div元素,它包含一个无序列表(ul)和一个标题(h2)。这个div元素在firstFlagtrue时显示。
  3. firstFlagfalse时,通过绑定dataURL属性来显示一个图片,该图片的路径由dataURL提供。
  4. <script>标签中,首先导入了html2canvas库。
  5. data属性中,定义了两个变量:dataURL用于存储生成的图片路径,firstFlag用于控制显示的内容。
  6. mounted方法中,使用html2canvas函数将指定的元素(通过选择器#captureId选取)转换为画布,并将画布转换为图片(png格式),最后将生成的图片路径赋值给dataURL,同时将firstFlag设置为false,以显示图片。
  7. methods中暂时没有定义任何方法。
  8. <style>标签中定义了样式,使用了Less语法,scoped属性表示样式只作用于当前组件。
相关推荐
imkaifan2 分钟前
工作流(Worker/Graph)配置对象如何解读、子图
javascript·工作流·(worker/graph)·配置对象如何解读·子图
向日的葵0062 分钟前
vue3路由的replace属性(四)
前端·javascript·vue.js·vue路由
阿猫的故乡4 分钟前
Vue模板引用和组件暴露:ref拿DOM、defineExpose调方法,案例多到眼花
前端·javascript·vue.js
薛定谔的猫-菜鸟程序员8 分钟前
从Electron到Tauri,Rust+Vue(Tauri) 实现超高性能桌面日志应用开发,以及开发避坑指南
vue.js·rust·electron
ZC跨境爬虫9 小时前
跟着 MDN 学JavaScript day_7:数学运算与逻辑判断实战测试
开发语言·前端·javascript·学习·ecmascript
凌云拓界10 小时前
文件管理:让AI安全操作你的电脑 ——CogitoAgent开发实战(三)
javascript·人工智能·架构·开源·node.js
凌云拓界10 小时前
联网能力:让AI看见更广阔的世界 ——CogitoAgent开发实战(四)
javascript·人工智能·架构·node.js·创业创新
HYCS11 小时前
用pixi.js实现fabric.js(六):从线性代数的角度理解编辑器交互
前端·javascript·canvas
you458012 小时前
学成在线--day02 CMS前端开发(含Vue基础知识得回顾)
前端·javascript·vue.js
想吃火锅100512 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode