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

前端Echarts自適應(yīng)分辨率和縮放功能代碼實例

 更新時間:2024年07月29日 10:26:21   作者:Lucky小維  
ECharts提供了自適應(yīng)功能,可以自動調(diào)整圖表大小以適應(yīng)屏幕變化,下面這篇文章主要給大家介紹了關(guān)于前端Echarts自適應(yīng)分辨率和縮放功能的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

版本

yarn add echarts@4.9.0
yarn add resize-detector@0.3.0

mixins-resize.js

import { addListener, removeListener } from 'resize-detector';
import _ from 'lodash';

export default {
  mounted() {
    const { onResize } = this;
    this.__resizeHandler = _.debounce(() => {
      if (typeof onResize === 'function') onResize();
    }, 100);

    this.$nextTick(() => {
      addListener(this.$el, this.__resizeHandler);
    });
  },
  beforeDestroy() {
    removeListener(this.$el, this.__resizeHandler);
  }
}

dataZoom.js

export const echartOptions = {
  dataZoom: [
    {
      type: 'slider', //滑動條型數(shù)據(jù)縮放組件
      start: 90, //數(shù)據(jù)窗口的起始位置百分比
      end: 100, //數(shù)據(jù)窗口的結(jié)束位置百分比
      height: 6, //數(shù)據(jù)縮放組件的高度
      bottom: 20, //數(shù)據(jù)縮放組件距離底部的距離
      realtime: false, //是否實時顯示,這里是 false,表示拖動結(jié)束時才觸發(fā)數(shù)據(jù)變化
      backgroundColor: '#EDF0F5', //數(shù)據(jù)縮放組件的背景色
      handleSize: 12, //滑塊的大小
      //滑塊的圖標(biāo)
      handleIcon:
        'image://',

      dataBackground: {
        //數(shù)據(jù)區(qū)域的背景配置
        lineStyle: {
          //數(shù)據(jù)區(qū)域邊界線的樣式配置,這里設(shè)置為透明
          opacity: 0,
        },
        areaStyle: {
          //數(shù)據(jù)區(qū)域填充樣式配置,這里設(shè)置為透明
          opacity: 0,
        },
      },
      selectedDataBackground: {
        //選中數(shù)據(jù)區(qū)域的背景配置
        lineStyle: {
          //選中數(shù)據(jù)區(qū)域邊界線的樣式配置,這里設(shè)置為透明
          opacity: 0,
        },
        areaStyle: {
          // 選中數(shù)據(jù)區(qū)域填充樣式配置,這里設(shè)置為透明
          opacity: 0,
        },
        brushStyle: {
          //選中數(shù)據(jù)區(qū)域的刷子樣式配置,這里設(shè)置邊框顏色為紅色
          borderColor: '#f00',
        },
      },
      // fillerColor: ' #A3A1FB', //數(shù)據(jù)區(qū)域的填充顏色 紫色
      textStyle: {
        color: 'transparent', //文本顏色,這里設(shè)置為透明
      },
    },
  ],
}

使用

<template>
  <div class="mod-demo-echarts">
    <el-row :gutter="20">
      <el-col :span="17">
        <el-card>
          <div id="lucky_chart" style="min-height: 400px"></div>
        </el-card>
      </el-col>
    </el-row>
  </div>
</template>
<script>
import { deepClone } from '@/views/common'
import { echartOptions } from '@/views/common/dataZoom.js'
import ResizeMixins from '@/views/common/mixins-resize.js'
export default {
  mixins: [ResizeMixins],
  data() {
    return {
      chartLine: null,
      myChart: null,
      chartPie: null,
      chartScatter: null,
    }
  },
  mounted() {
    this.initLuckyChart()
  },

  methods: {
    initLuckyChart() {
      let dataZoom = deepClone(echartOptions.dataZoom)
      let xLabel = ['8:05', '8:10', '8:15', '8:25', '8:30', '8:35', '8:40', '8:45', '8:55', '9:00', '9:05', '9:10'] //x軸數(shù)據(jù)
      let dataValue = [120, 130, 140, 135, 134, 115, 156, 115, 112, 215, 134, 142] //y軸數(shù)據(jù)1
      let dataValue1 = [1.0, 3.0, 2.0, 1.0, 3, 1, 2, 3.2, 4.5, 5.0, 4.3, 3] //y軸數(shù)據(jù)2
      let dataValue2 = [3, 6, 7, 15, 8, 5, 2, 5, 4, 2, 10, 3] //y軸數(shù)據(jù)3

      let colors = ['#a5c5d4', '#91CC75', '#EE6666'] //顏色
      let option = {
        dataZoom: dataZoom,
        color: colors,
        tooltip: {
          //懸浮放上面的提示
          trigger: 'axis', //坐標(biāo)軸觸發(fā)
          axisPointer: {
            type: 'line', //直線指示器
          },
        },
        grid: {
          right: '20%', //echarts離容器左側(cè)的距離
        },
        toolbox: {
          //工具欄。內(nèi)置有導(dǎo)出圖片,數(shù)據(jù)視圖,動態(tài)類型切換,數(shù)據(jù)區(qū)域縮放,重置五個工具。
          feature: {
            dataView: { show: true, readOnly: false }, //數(shù)據(jù)視圖
            restore: { show: true }, //重置
            saveAsImage: { show: true }, //下載
          },
        },
        legend: {
          //圖例組件展現(xiàn)了不同系列的標(biāo)記(symbol),顏色和名字。可以通過點擊圖例控制哪些系列不顯示
          data: ['濁度', 'PH', '水溫'], //就是圖表上面正中間那3,點擊某個某個就能隱藏
        },
        xAxis: [
          {
            type: 'category', //類目軸,適用于離散的類目數(shù)據(jù)。為該類型時類目數(shù)據(jù)可自動從 series.data 或 dataset.source 中取,或者可通過 xAxis.data 設(shè)置類目數(shù)據(jù)
            boundaryGap: false, //false從0開始,最少x會放0位置
            axisTick: {
              //坐標(biāo)軸刻度|和數(shù)據(jù)是對齊的,加上這個
              alignWithLabel: true,
            },
            // prettier-ignore
            data: xLabel, //x軸數(shù)據(jù)
          },
        ],
        yAxis: [
          //直角坐標(biāo)系 grid 中的 y 軸,一般情況下單個 grid 組件最多只能放左右兩個 y 軸,多于兩個 y 軸需要通過配置 offset 屬性防止同個位置多個 Y 軸的重疊。
          {
            type: 'value', //適用于連續(xù)數(shù)據(jù)
            name: '濁度(ntu)', //坐標(biāo)軸名稱
            position: 'left', //左邊
            alignTicks: true, //開啟該配置項自動對齊刻度
            min: 0, //初始
            max: 1000, //結(jié)束值
            interval: 200, //間距   如果沒這3,會自適應(yīng)數(shù)據(jù)
            axisLine: {
              show: false, //y軸|  是否顯示
              lineStyle: {
                color: colors[0], //顏色
              },
            },
            splitLine: {
              //隱藏縱軸的橫線
              show: true, //展示
              lineStyle: {
                color: '#DCDFE6 ', //虛線顏色
                type: 'dashed', //虛線
              },
            },
            axisLabel: {
              //縱軸文字,就是0 200 400 600 800 1000
              show: true,
              formatter: '{value} ',
            },
          },
          {
            type: 'value', //適用于連續(xù)數(shù)據(jù)
            name: 'PH',
            position: 'right', //右邊
            alignTicks: true, //開啟該配置項自動對齊刻度
            min: 0, //初始
            max: 14, //結(jié)束值
            interval: 3, //間距   如果沒這3,會自適應(yīng)數(shù)據(jù)
            splitLine: {
              show: false, //y軸|  是否顯示
              lineStyle: {
                color: '#1160a0',
                type: 'solid', //實體線
              },
            },
            axisLine: {
              //縱軸文字,就是0 3 6 9 12 14
              show: false,
              lineStyle: {
                color: colors[1],
              },
            },
            axisLabel: {
              formatter: '{value} ',
            },
          },
          {
            type: 'value',
            name: '水溫(°C)',
            show: true, // 添加該配置來隱藏水溫縱軸
            position: 'right',
            alignTicks: true,
            min: 0,
            max: 100,
            interval: 20,
            offset: 80, //向右偏移80
            axisLine: {
              show: false, //y軸|  是否顯示
              lineStyle: {
                color: colors[2],
              },
            },
            splitLine: {
              //隱藏縱軸的橫線
              show: false,
              lineStyle: {
                color: '#DCDFE6 ',
                type: 'dashed',
              },
            },
            axisLabel: {
              //縱軸文字
              formatter: '{value} ',
            },
          },
        ],
        series: [
          //數(shù)據(jù)
          {
            name: '濁度',
            type: 'line', //折線
            symbol: 'none', // 默認(rèn)是空心圓(中間是白色的),改成實心圓
            smooth: true, //是否平滑
            color: '',
            areaStyle: {
              normal: {
                //線性漸變,前4個參數(shù)分別是x0,y0,x2,y2(范圍0~1);相當(dāng)于圖形包圍盒中的百分比。如果最后一個參數(shù)是‘true',則該四個值是絕對像素位置。
                color: new this.$echarts.graphic.LinearGradient(
                  0,
                  0,
                  0,
                  1,
                  [
                    {
                      offset: 0,
                      color: '#bed4e5',
                    },
                    {
                      offset: 0.6,
                      color: '#aac8d9',
                    },
                    {
                      offset: 1,
                      color: '#9dbec9',
                    },
                  ],
                  false
                ),
              },
            },
            data: dataValue,
          },
          {
            name: 'PH',
            type: 'line',
            yAxisIndex: 1, //默認(rèn)是0就左邊那個y軸,1是右邊第一個
            data: dataValue1,
          },
          {
            name: '水溫',
            type: 'line',
            symbol: 'none', // 默認(rèn)是空心圓(中間是白色的),改成實心圓
            smooth: true,
            yAxisIndex: 2,
            areaStyle: {
              normal: {
                //線性漸變,前4個參數(shù)分別是x0,y0,x2,y2(范圍0~1);相當(dāng)于圖形包圍盒中的百分比。如果最后一個參數(shù)是‘true',則該四個值是絕對像素位置。
                color: new this.$echarts.graphic.LinearGradient(
                  0,
                  0,
                  0,
                  1,
                  [
                    {
                      offset: 0,
                      color: '#c1a3aa',
                    },
                    {
                      offset: 0.6,
                      color: '#b19aa3',
                    },
                    {
                      offset: 1,
                      color: '#a78c95',
                    },
                  ],
                  false
                ),
              },
            },
            data: dataValue2,
          },
        ],
      }

      this.myChart = this.$echarts.init(document.getElementById('lucky_chart'))
      this.myChart.setOption(option)
    },
    onResize() {
      this.myChart && this.myChart.resize()
      // this.$refs.swiper1 && this.$refs.swiper1.resize();
    },
  },
}
</script>

總結(jié) 

到此這篇關(guān)于前端Echarts自適應(yīng)分辨率和縮放功能的文章就介紹到這了,更多相關(guān)Echarts自適應(yīng)分辨率和縮放內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論