国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

將Echarts圖表導(dǎo)出為圖片的三種方式

這篇具有很好參考價值的文章主要介紹了將Echarts圖表導(dǎo)出為圖片的三種方式。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

echarts導(dǎo)出圖片,ECharts,echarts,前端,vue.js

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

????1.npm安裝

npm install html2canvas

? ? ? ?yarn安裝

yarn add html2canvas

? ? 2.組件引入

import html2canvas from "html2canvas"

? ? 3.代碼文章來源地址http://www.zghlxwxcb.cn/news/detail-524184.html

// 導(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)簽,實現(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實例
  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)簽,實現(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>

到了這里,關(guān)于將Echarts圖表導(dǎo)出為圖片的三種方式的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進(jìn)行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • vue-echarts踩坑,本地開發(fā)可以渲染echarts圖表,線上環(huán)境圖表渲染不出來

    vue-echarts踩坑,本地開發(fā)可以渲染echarts圖表,線上環(huán)境圖表渲染不出來

    main.js 全局注冊v-chart組件 在頁面中使用 如上圖,我開始寫的靜態(tài)數(shù)據(jù),在data中定義了chartOption1:{…配置項…}, 在接口數(shù)據(jù)返回之后,更新了配置項,在本地開發(fā)環(huán)境可以正常渲染。但是線上環(huán)境出不來,也不報錯,接口數(shù)據(jù)一切正常。 解決辦法: 無奈最后沒有使用‘vue-e

    2024年01月18日
    瀏覽(22)
  • 圖表庫-Echarts

    圖表庫-Echarts

    一. Echarts 1. 概述 常見的數(shù)據(jù)可視化庫: D3.js 目前 Web 端評價最高的 Javascript 可視化工具庫(入手難) ECharts.js 百度出品的一個開源 Javascript 數(shù)據(jù)可視化庫 Highcharts.js 國外的前端數(shù)據(jù)可視化庫,非商用免費,被許多國外大公司所使用AntV 螞蟻金服全新一代數(shù)據(jù)可視化解決方案 等等

    2023年04月18日
    瀏覽(19)
  • Echarts實現(xiàn)3d圖表

    Echarts實現(xiàn)3d圖表

    注意:在使用一些3d類的echart的時候會發(fā)現(xiàn)報下面的錯誤 ?這個是因為echarts引用3d圖形需要引入echarts和echarts-gl (這里我們可能會遺漏掉引入echarts-gl) 要注意不同版本echarts對應(yīng)不同版本echarts-gl 【如果版本不匹配就重新安裝對應(yīng)版版本】

    2024年02月16日
    瀏覽(21)
  • 項目中的Echarts圖表統(tǒng)計

    項目中的Echarts圖表統(tǒng)計

    前情提要:本次Echarts數(shù)據(jù)可視化基于圖書管理系統(tǒng)設(shè)計 Echarts是一個開源的 可視化圖表庫 ,由百度前端技術(shù)部開發(fā)維護(hù)。它基于JavaScript語言實現(xiàn),通過簡單的配置即可生成豐富多樣的圖表,包括柱狀圖、折線圖、餅圖等等。Echarts支持各種數(shù)據(jù)格式,如JSON、XML、CSV等,同時

    2024年02月08日
    瀏覽(18)
  • Vue+Echarts圖表動態(tài)適配

    目錄 前言 一、問題背景 二、解決方案 1.在Vue組件中引入Echarts 2.初始化圖表 3.監(jiān)聽resize事件 4.銷毀圖表 三、優(yōu)化方案 1.防抖 2.節(jié)流 四、總結(jié) 在實際的前端開發(fā)過程中,動態(tài)適配是一個非常重要的問題。在數(shù)據(jù)可視化的場景下,圖表的動態(tài)適配尤為重要。在本篇博客中,我們

    2024年02月05日
    瀏覽(27)
  • vue+echarts圖表的基本使用

    vue+echarts圖表的基本使用

    在實際開發(fā)當(dāng)中,我們經(jīng)常需要用到一些圖表來實現(xiàn)數(shù)據(jù)可視化,這時候 echarts 可以幫助我們實現(xiàn)數(shù)據(jù)的展示。這里將介紹如何使用前端框架vue+echarts來實現(xiàn)數(shù)據(jù)可視化。 長話短說,echarts就是一個幫助數(shù)據(jù)可視化的庫。 代碼:直接復(fù)制代碼創(chuàng)建一個vue組件,到App中引入組件

    2024年02月15日
    瀏覽(54)
  • 小程序使用echarts圖表-雷達(dá)圖

    小程序使用echarts圖表-雷達(dá)圖

    本文介紹下小程序中如何使用echarts 如果是通過npm安裝,這樣是全部安裝的,體積有點大 我這邊是使用echarts中的一個組件來實現(xiàn)的,下邊是具體流程,實際效果是沒有外邊的紅色邊框的,加紅色邊框的效果是這篇說明 1.echarts光網(wǎng)有提到一個小程序組件 echarts-for-weixin點擊下載

    2024年01月21日
    瀏覽(20)
  • ECharts 圖表簡單示例,中國地圖
  • uniapp小程序使用原生echarts非第三方封裝 小程序使用echarts 圖表 可視化

    uniapp小程序使用原生echarts非第三方封裝 小程序使用echarts 圖表 可視化

    前言:之前小程序做的圖表,當(dāng)時沒找到太多使用echarts的教程,大多都是二次封裝的。連uniapp都是推薦別人二次封裝的圖表,然后用了之后呢,發(fā)現(xiàn)不是自己想要的效果(也許是自己對別人二次封裝的代碼不夠熟悉吧 ),然后干脆摸索下uniapp引入echarts圖表(非他人封裝的)

    2024年02月09日
    瀏覽(34)
  • ECharts數(shù)據(jù)可視化--常用圖表類型

    ECharts數(shù)據(jù)可視化--常用圖表類型

    目錄 一.柱狀圖 1.基本柱狀圖 ?1.1最簡單的柱狀圖 ?編輯 ??1.2多系列柱狀圖? ?1.3柱狀圖的樣式? ? ? ? ? (1)柱條樣式 ? ? ? ?? ????????(2)柱條的寬度和高度 ? ? ? ? (3)柱條間距 ? ? ? ? (4)為柱條添加背景顏色 ?編輯 2.堆疊柱狀圖 3.動態(tài)排序柱狀圖 4.階梯

    2024年02月05日
    瀏覽(30)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包