欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

將Echarts圖表導(dǎo)出為圖片的3種方法總結(jié)

 更新時間:2023年06月30日 09:45:35   作者:慢慢manman  
這篇文章主要給大家介紹了關(guān)于將Echarts圖表導(dǎo)出為圖片的3種方法,Echarts是一種基于JavaScript的可視化庫,用于創(chuàng)建豐富、交互式的圖表和地圖,而Excel是一種電子表格軟件,用于數(shù)據(jù)處理和分析,需要的朋友可以參考下

 第一種 使用 html2canvas 對dom元素截圖

1.npm安裝

npm install html2canvas

yarn安裝

yarn add html2canvas

2.組件引入

import html2canvas from "html2canvas"

3.代碼

// 導(dǎo)出多張圖表為一張圖片
// dmo元素里的內(nèi)容轉(zhuǎn)換為canvas,并將canvas下載為圖片
const download = () => {
  // 轉(zhuǎn)換成canvas
  html2canvas(document.getElementById("echarts")).then(function (canvas) {
    var img = canvas
      .toDataURL("image/png")
      .replace("image/png", "image/octet-stream");
    // 創(chuàng)建a標(biāo)簽,實(shí)現(xiàn)下載
    var creatIMg = document.createElement("a");
    creatIMg.download = "圖表.png"; // 設(shè)置下載的文件名,
    creatIMg.href = img; // 下載url
    document.body.appendChild(creatIMg);
    creatIMg.click();
    creatIMg.remove(); // 下載之后把創(chuàng)建的元素刪除
  });
};

第二種 使用Echarts官方文檔中的 getDataURL 方法

// 導(dǎo)出單個圖表圖片
function Export() {
  var img = new Image();
  // pieMyChart1 要導(dǎo)出的圖表
  img.src = pieMyChart1.value.getDataURL({
    type: "png",
    pixelRatio: 1, //放大2倍
    backgroundColor: "#fff",
  });
  img.onload = function () {
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);
    var dataURL = canvas.toDataURL("image/png");
    var a = document.createElement("a");
    var event = new MouseEvent("click");
    a.download = "圖片.png" || "下載圖片名稱";
    // 將生成的URL設(shè)置為a.href屬性
    a.href = dataURL;
    // 觸發(fā)a的單擊事件
    a.dispatchEvent(event);
    a.remove();
  };
}

第三種 使用Echarts官方文檔中的 toolbox

toolbox: {
      show: true,
      orient: "vertical",
      left: "right",
      top: "center",
      feature: {
        saveAsImage: { show: true },  // 保存圖表
      },
},

完整代碼

<template>
  <el-scrollbar>
    <div style="padding: 10px 10px 0">
      <el-button type="primary" @click="refresh">刷新</el-button>
      <el-button @click="download">下載</el-button>
      <el-button @click="Export">導(dǎo)出pie</el-button>
    </div>
    <el-divider />
    <div id="echarts">
      <div class="about" id="main"></div>
      <div class="about" id="pie"></div>
    </div>
  </el-scrollbar>
</template>
<script setup>
import { ref, getCurrentInstance, onMounted } from "vue";
import html2canvas from "html2canvas";
const { appContext } = getCurrentInstance();
const { $echarts } = appContext.config.globalProperties;
onMounted(() => {
  setEcharts();
});
const pieMyChart1 = ref(null);
const setEcharts = () => {
  // 基于準(zhǔn)備好的dom,初始化echarts實(shí)例
  var myChart = $echarts.init(document.getElementById("main"));
  // 繪制圖表
  myChart.setOption({
    title: {
      text: "ECharts 入門示例",
    },
    tooltip: {},
    xAxis: {
      data: ["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"],
      axisTick: {
        // 坐標(biāo)軸刻度標(biāo)簽
        show: false,
      },
    },
    yAxis: {
      type: "value", // 類型數(shù)值軸
      min: 0,
      max: 40,
      splitNumber: 8, // 坐標(biāo)軸的分割段數(shù)
      axisLine: {
        show: true,
      },
      axisTick: {
        show: false, // 隱藏刻度
      },
    },
    series: [
      {
        name: "銷量",
        type: "bar",
        label: {
          show: true,
          fontSize: 16,
        },
        data: [5, 20, 36, 10, 10, 20],
        itemStyle: {
          borderRadius: 5,
          borderWidth: 1,
          borderType: "solid",
          borderColor: "#73c0de",
        },
      },
    ],
  });
  // 繪制圖表
  const pieMyChart = $echarts.init(document.getElementById("pie"));
  pieMyChart1.value = pieMyChart;
  pieMyChart.setOption({
    title: {
      text: "ECharts 入門示例",
      titleStyle: {
        lineHeight: 18,
      },
      top: "0px",
    },
    tooltip: {},
    legend: {
      orient: "vertical",
      x: "left",
      data: ["A", "B", "C", "D", "E"],
      top: "80px",
    },
    toolbox: {
      show: true,
      orient: "vertical",
      left: "right",
      top: "center",
      feature: {
        saveAsImage: { show: true }, // 保存圖表
      },
    },
    series: [
      {
        type: "pie",
        data: [
          {
            value: 335,
            name: "A",
          },
          {
            value: 234,
            name: "B",
          },
          {
            value: 548,
            name: "C",
          },
          {
            value: 500,
            name: "D",
          },
          {
            value: 500,
            name: "E",
          },
        ],
      },
    ],
  });
};
// 頁面刷新
const refresh = () => {
  location.reload();
};
// 導(dǎo)出多張圖表為一張圖片
// dmo元素里的內(nèi)容轉(zhuǎn)換為canvas,并將canvas下載為圖片
const download = () => {
  // 轉(zhuǎn)換成canvas
  html2canvas(document.getElementById("echarts")).then(function (canvas) {
    var img = canvas
      .toDataURL("image/png")
      .replace("image/png", "image/octet-stream");
    // 創(chuàng)建a標(biāo)簽,實(shí)現(xiàn)下載
    var creatIMg = document.createElement("a");
    creatIMg.download = "圖表.png"; // 設(shè)置下載的文件名,
    creatIMg.href = img; // 下載url
    document.body.appendChild(creatIMg);
    creatIMg.click();
    creatIMg.remove(); // 下載之后把創(chuàng)建的元素刪除
  });
};
// 導(dǎo)出單個圖表圖片
function Export() {
  var img = new Image();
  img.src = pieMyChart1.value.getDataURL({
    type: "png",
    pixelRatio: 1, //放大2倍
    backgroundColor: "#fff",
  });
  img.onload = function () {
    var canvas = document.createElement("canvas");
    canvas.width = img.width;
    canvas.height = img.height;
    var ctx = canvas.getContext("2d");
    ctx.drawImage(img, 0, 0);
    var dataURL = canvas.toDataURL("image/png");
    var a = document.createElement("a");
    var event = new MouseEvent("click");
    a.download = "圖片.png" || "下載圖片名稱";
    // 將生成的URL設(shè)置為a.href屬性
    a.href = dataURL;
    // 觸發(fā)a的單擊事件
    a.dispatchEvent(event);
    a.remove();
  };
}
</script>
<style>
.el-scrollbar {
  height: calc(100vh - 59px);
}
.el-divider--horizontal {
  margin: 10px 0;
}
#echarts {
  padding: 20px;
  width: 600px;
}
#main {
  height: 300px;
  width: 600px;
}
#pie {
  height: 300px;
  width: 600px;
}
</style>

總結(jié)

到此這篇關(guān)于將Echarts圖表導(dǎo)出為圖片的3種方法的文章就介紹到這了,更多相關(guān)Echarts圖表導(dǎo)出為圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:

相關(guān)文章

  • 微信小程序開發(fā)常見問題及解決方案

    微信小程序開發(fā)常見問題及解決方案

    這篇文章主要介紹了微信小程序開發(fā)常見問題及解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-07-07
  • JavaScript 中this指向問題案例詳解

    JavaScript 中this指向問題案例詳解

    這篇文章主要介紹了JavaScript 中this指向問題案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • JQuery中serialize() 序列化

    JQuery中serialize() 序列化

    這篇文章主要介紹了JQuery中serialize() 序列化,十分的細(xì)致全面,推薦給大家,
    2015-03-03
  • JS實(shí)現(xiàn)問卷星自動填問卷腳本并在兩秒自動提交功能

    JS實(shí)現(xiàn)問卷星自動填問卷腳本并在兩秒自動提交功能

    這篇文章主要介紹了JS實(shí)現(xiàn)問卷星自動填問卷腳本兩秒自動提交功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2017-08-08
  • JavaScript中如何判斷一個值的類型

    JavaScript中如何判斷一個值的類型

    在js中有一個運(yùn)算符可以幫助我們判斷一個值的類型,它就是typeof運(yùn)算符。下面通過本文給大家分享JavaScript中如何判斷一個值的類型,需要的朋友參考下吧
    2017-09-09
  • JS實(shí)現(xiàn)瀑布流布局

    JS實(shí)現(xiàn)瀑布流布局

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)瀑布流布局效果展示,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • select自定義小三角樣式代碼(實(shí)用總結(jié))

    select自定義小三角樣式代碼(實(shí)用總結(jié))

    這篇文章主要介紹了select自定義小三角樣式,通過css HTML js 代碼詳細(xì)展示了操作過程,自定義小三角樣式,也可以做出select文字居中的效果,需要的朋友可以參考下
    2017-08-08
  • 使用electron制作滿屏心特效的示例代碼

    使用electron制作滿屏心特效的示例代碼

    這篇文章主要介紹了使用electron制作滿屏心特效的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-11-11
  • cypress中豐富的調(diào)試工具使用方法

    cypress中豐富的調(diào)試工具使用方法

    這篇文章主要為大家介紹了cypress中豐富的調(diào)試工具及使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-06-06
  • js調(diào)用本地exe程序的兩種方式小結(jié)

    js調(diào)用本地exe程序的兩種方式小結(jié)

    這篇文章主要介紹了js調(diào)用本地exe程序的兩種方式小結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11

最新評論