vue3中实现echarts打印功能

目录

一、创建项目

老规矩,先从创建项目开始

ts 复制代码
npm create vite@latest print-demo(项目名称)

第一步出现的框架选择vue,然后回车

第二步的语言就选TS,一般vue3都是搭配TS使用的,选择后回车

然后会出现三个指令,三个指令都是依次执行的,缺一不可,

依次执行完成以后,会出现一个地址,这个地址就是项目的地址,按住ctrl然后鼠标点击,就可以直接打开项目了

然后打开就是这样的一个页面,

二、项目引入echarts

1、下载依赖

官网中有详细介绍,感兴趣的可以看看官网地址

2、项目引用

官网中有详细介绍,我这里就跳过这一步,直接先写一个实例出来

3、编写建议echarts图表

官网上例子很多,我就不做详细介绍了,直接贴我用的官网的一个例子

ts 复制代码
<script setup lang="ts">
import { onMounted, ref } from 'vue'
import * as echarts from 'echarts';
defineProps<{ msg: string }>()

const count = ref(0)
const option = ref({

  tooltip: {
    trigger: 'axis',
    axisPointer: {
      type: 'cross',
      label: {
        backgroundColor: '#6a7985'
      }
    }
  },
  legend: {
    data: ['Email', 'Union Ads', 'Video Ads', 'Direct', 'Search Engine']
  },

  grid: {
    left: '3%',
    right: '4%',
    bottom: '3%',
    containLabel: true
  },
  xAxis: [
    {
      type: 'category',
      boundaryGap: false,
      data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
    }
  ],
  yAxis: [
    {
      type: 'value'
    }
  ],
  series: [
    {
      name: 'Email',
      type: 'line',
      stack: 'Total',
      areaStyle: {},
      emphasis: {
        focus: 'series'
      },
      data: [120, 132, 101, 134, 90, 230, 210]
    },
    {
      name: 'Union Ads',
      type: 'line',
      stack: 'Total',
      areaStyle: {},
      emphasis: {
        focus: 'series'
      },
      data: [220, 182, 191, 234, 290, 330, 310]
    },
    {
      name: 'Video Ads',
      type: 'line',
      stack: 'Total',
      areaStyle: {},
      emphasis: {
        focus: 'series'
      },
      data: [150, 232, 201, 154, 190, 330, 410]
    },
    {
      name: 'Direct',
      type: 'line',
      stack: 'Total',
      areaStyle: {},
      emphasis: {
        focus: 'series'
      },
      data: [320, 332, 301, 334, 390, 330, 320]
    },
    {
      name: 'Search Engine',
      type: 'line',
      stack: 'Total',
      label: {
        show: true,
        position: 'top'
      },
      areaStyle: {},
      emphasis: {
        focus: 'series'
      },
      data: [820, 932, 901, 934, 1290, 1330, 1320]
    }
  ]
})
const operateCharts = ref<HTMLElement | null>(null)
onMounted(() => {
  initChart()
})
const initChart = () => {
  if (operateCharts.value) {
    const chart = echarts.init(operateCharts.value)
    chart.setOption(option.value)
    window.addEventListener('resize', function () {
      chart.resize()
    })
  }


}
</script>

<template>
  <div ref="operateCharts" style="width: 500px;height:500px">

  </div>
</template>

<style scoped>
.read-the-docs {
  color: #888;
}
</style>

这个代码出来的效果如下

三、打印功能

1、增加打印按钮

代码增加如下

ts 复制代码
<template>
  <div ref="operateCharts" style="width: 500px;height:500px">
  </div>
  <button>打印</button>
</template>

页面如下,我这里给按钮加了一个边框,让按钮看的更清楚,大家可加可不加

在style.css中

2、打印方法

①给按钮绑定方法

ts 复制代码
  <button @click="Print">打印</button>
  //写一个空的方法
  const Print = ()=>{}

②直接调用window.print();

ts 复制代码
const Print = () => {
      window.print();
}

3、效果

点击打印,就调出打印的页面了,这是最简单的一个方式,后期会更新稍微复杂一些的,请关注后期帖子

相关推荐
蜡台18 小时前
UniApp WebView 组件宽高设置与动态适配全方案
前端·javascript·uniapp·webview·iframe
半个烧饼不加肉18 小时前
JS 底层探究-- 调用栈(Call Stack)
开发语言·前端·javascript
码上暴富18 小时前
el-table表格全屏/管理显示字段/导出功能封装
vue.js
子午18 小时前
基于DeepSeek的智能校园教务管理系统~Web管理系统+Vue3+Python+DeepSeek智能问答
前端
change_fate18 小时前
ERR_PNPM_WORKSPACE_PKG_NOT_FOUND In ...
java·服务器·前端
超人不会飞_Jay19 小时前
26.6.3Vue笔记
前端·vue.js·笔记
御坂1002719 小时前
Vue - @change应用实现下拉框联动功能
前端·javascript·vue.js
小雨下雨的雨19 小时前
基于 Electron 运行时的鸿蒙PC桌面应用-安全可靠的随机密码生成工具
前端·javascript·华为·electron·前端框架·鸿蒙
瘦瘦瘦大人19 小时前
Vue 项目实现关闭/刷新浏览器窗口前的离开确认提示
前端·javascript·vue.js
大家的林语冰19 小时前
尤雨溪官宣:Vite+ 全员加盟 Cloudflare,正式进军全栈开发和 AI 部署云平台!
前端·javascript·vite