echarts使图表组件根据屏幕尺寸变更而重新渲染大小

news2024/9/23 1:33:53

效果图:

通过      window.addEventListener('resize', this.resizeChart); 实现

完整代码:

<template>
  <div class="dunBlock">
    <div class="char2" id="char2" ref="chart"></div>
  </div>
</template>

<script>
  import * as echarts from 'echarts';

  export default {
    props: ['chartData', 'colorArr'],
    data() {
      return {
        myChart: null,
      };
    },
    watch: {
      chartData: function() {
        this.initCC();
      }
    },
    mounted() {
      this.initCC();
      window.addEventListener('resize', this.resizeChart);
    },
    beforeDestroy() {
      window.removeEventListener('resize', this.resizeChart);
    },
    methods: {
      initCC() {
        if (!this.chartData || !this.colorArr) return;

        const chartDom = this.$refs.chart;
        this.myChart = echarts.init(chartDom);

        const option = {
          tooltip: {
            trigger: 'axis',
            axisPointer: {
              type: 'cross',
              label: {
                backgroundColor: '#6a7985',
              },
            },
            formatter: function(params) {
              let result = `${params[0].axisValue}<br/>`;
              params.forEach(item => {
                result += `${item.marker}${item.seriesName}: ${item.value}<br/>`;
              });
              return result;
            },
          },
          legend: {
            data: ['折线数据', '柱状数据1', '柱状数据2'],
          },
          grid: {
            left: '3%',
            right: '4%',
            bottom: '6%',
            containLabel: true,
          },
          dataZoom: [{
              type: 'inside', // 内置滚动
              xAxisIndex: 0,
              start: 0, // 初始滚动位置
              end: 50, // 显示的数据比例
            },
            {
              show: true, // 显示外部滚动条
              xAxisIndex: 0,
              height: 10, // 滚动条高度
              start: 0, // 初始滚动位置
              end: 50, // 显示的数据比例
              bottom: 0
            }
          ],
          xAxis: [{
            type: 'category',
            boundaryGap: true,
            data: this.chartData.labels,
            axisLine: {
              show: false,
            },
            axisTick: {
              show: false,
              alignWithLabel: false,
            },
            axisLabel: {
              overflow: 'break', // 超出宽度换行,需要设置width
              interval: 1,
              margin: 7,
              fontSize: 11,
              rotate: 90, // 初始旋转角度
              formatter: function(value) {
                // 根据标签长度自适应旋转角度
                const labelLength = value.length;
                if (labelLength > 10) {
                  return `{rotate|${value}}`; // 长标签旋转显示
                } else {
                  return value; // 短标签正常显示
                }
              },
              rich: {
                rotate: {
                  rotate: 45,
                }
              },
            },
          }, ],
          yAxis: [{
            type: 'value',
            axisLine: {
              show: false,
            },
            axisTick: {
              show: false,
            },
            splitLine: {
              show: false,
            },
          }, ],
          series: [{
              name: '折线数据',
              type: 'line',
              data: this.chartData.lineData,
              smooth: true,
              areaStyle: {
                color: this.colorArr[0] || 'rgba(150, 200, 250, 0.5)',
              },
              lineStyle: {
                color: this.colorArr[1] || '#5470C6',
              },
              symbol: 'circle',
              symbolSize: 10,
              itemStyle: {
                color: this.colorArr[1] || '#5470C6',
              },
              label: {
                show: true,
                position: 'top',
                formatter: '{c}',
              },
            },
            {
              name: '柱状数据1',
              type: 'bar',
              data: this.chartData.barData1,
              barGap: '-100%',
              barWidth: '40%',
              itemStyle: {
                color: this.colorArr[2] || 'rgba(60, 160, 180, 0.8)',
              },
              label: {
                show: true,
                position: 'insideTop',
                formatter: '{c}',
                color: '#fff',
              },
            },
            {
              name: '柱状数据2',
              type: 'bar',
              data: this.chartData.barData2,
              barWidth: '40%',
              itemStyle: {
                color: this.colorArr[3] || 'rgba(180, 60, 120, 0.8)',
              },
              label: {
                show: true,
                position: 'insideTop',
                formatter: '{c}',
                color: '#fff',
              },
            },
          ],
        };

        this.myChart.setOption(option);
      },
      resizeChart() {
        console.log('重新渲染图表');
        // 重新渲染图表
        this.myChart.resize();
      },
    },
  };
</script>

<style scoped>
  .dunBlock {
    width: 100%;
    height: 100%;
  }

  .char2 {
    width: 100%;
    height: 100%;
  }
</style>

引用示例:

<template>
  <div class="page">
    <div class="topBlock p_r">
      <div class="topTitle">
        整体运营
      </div>
      <div class="toptab" style="margin-left: 4rem;" @click="selectTop('1')"
        :class="topIdx==='1'?'tab-item-on':'tab-item-no'">
        employee
      </div>
      <div class="toptab" style="margin-left: 0.5rem;" @click="selectTop('2')"
        :class="topIdx==='2'?'tab-item-on':'tab-item-no'">
        hcp
      </div>
      <div class="toptab" style="margin-left: 2rem;" @click="selectTop('3')"
        :class="topIdx==='3'?'tab-item-on':'tab-item-no'">
        最近7天
      </div>
      <div class="toptab" style="margin-left: 0.5rem;" @click="selectTop('4')"
        :class="topIdx==='4'?'tab-item-on':'tab-item-no'">
        最新30天
      </div>
      <div class="" style="margin-left: 2rem;">
        <el-date-picker :default-value="$dayList" unlink-panels :picker-options="pickerOptions"
          style="height: 2.3rem;width: 260px;" v-model="timeParams" type="daterange" range-separator="至"
          start-placeholder="开始日期" end-placeholder="结束日期" @change="date_onChange">
        </el-date-picker>
      </div>

      <div class="topRight">
        当前选择日期范围:{{dayNow}}
      </div>
    </div>

    <div class="menuBlock p_r">
      <div class="menuItem" v-for="(item,idx) in menuList" :key="idx">
        <div class="menuTxt">
          {{item.txt}}
        </div>
        <div class="menuNum">
          {{item.mun}}
        </div>
      </div>
    </div>

    <div class="cards p_r">
      <div class="echartLineCard card">
        <echartLine v-if="echartLineDataShow" style="margin: 0 auto;" :colorArr="echartLineColorArr" :chartData="echartLineData"></echartLine>
      </div>
        <div class="echartLineCard card" style="margin-left: 1rem;">
          <echartLine v-if="echartLineDataShow" style="margin: 0 auto;" :colorArr="echartLineColorArr" :chartData="echartLineData"></echartLine>
        </div>
    </div>
  </div>
</template>

<script>

  import {
    getAllDatesInRange
  } from '@/utils/util'
  import echartLine from './components/echartLine'
  export default {
    components: {
      echartLine
    },
    data() {
      return {
        echartLineColorArr: ["#6358FE","#6358FE", "#1479FF", "#14A1F8"],
        echartLineData: {
          labels: getAllDatesInRange('2024-06-06','2024-08-12'),
          lineData: [220, 232, 191, 234, 290, 330, 310],
          barData1: [120, 132, 101, 134, 90, 230, 210],
          barData2: [150, 102, 101, 154, 190, 130, 110]
        },
        echartLineDataShow:false,
        menuList: [{
          txt: '总访问人数',
          mun: 60,
        }, {
          txt: '总访问量',
          mun: 1301,
        }, {
          txt: '工具',
          mun: 133,
        }, {
          txt: '首页',
          mun: 460,
        }, {
          txt: '自察',
          mun: 230,
        }, {
          txt: '疑诊',
          mun: 93,
        }, {
          txt: '筛查与诊断',
          mun: 34,
        }, {
          txt: '评估治疗',
          mun: 234,
        }, {
          txt: '随访',
          mun: 79,
        }, {
          txt: '多维护理',
          mun: 22,
        }],
        dayNow: '6/4/2024 - 8/8/2024',
        dataScreeningParams: {},
        topIdx: '',
        timeParams: ['', ''],
        pickerOptions: { //禁用今天之后的日期(包含今天)
          disabledDate(time) {
            return time.getTime() > Date.now();
          },
        },
      }
    },
    watch: {},
    mounted() {
      let arr1=[];
      let arr2=[];
      let arr3=[];
      let arrDate = getAllDatesInRange('2024-06-06','2024-08-12');
      arrDate.forEach((item,idx)=>{
        arr1.push(idx+1 +5)
        arr2.push(idx+1 +10)
        arr3.push(idx+1 +20)
      })
      this.echartLineData.lineData = arr3;
      this.echartLineData.barData1 = arr2;
      this.echartLineData.barData2 = arr1;
      this.$forceUpdate()
      this.echartLineDataShow=true;
    },
    methods: {
      selectTop(idx) {
        this.topIdx = idx;
      },
      async date_onChange(val) {

        if (this.isRqusetSuo) return;
        this.isRqusetSuo = true;
        setTimeout(() => {
          this.isRqusetSuo = false;
        }, 200)
        console.log('选中日期', val);
        this.timeParams = [timestampToTime(new Date(val[0])), timestampToTime(new Date(val[1]))];
        this.tabItemIdx = '999';

        this.loadHide = message.loading('加载中..', 0);
        setTimeout(this.loadHide, 4000)
        this.dataScreeningParams.startTime = timestampToTime(new Date(val[0]))
        this.dataScreeningParams.endTime = timestampToTime(new Date(val[1]))
        this.dataScreeningParams.type = ''
        // await this.getDSCharts()
      },
    },
  
  }
</script>

<style lang="less">
  .cards{
    margin: 1rem;
    .echartLineCard{
      width: 49rem;
      height: 30rem;
    }
  }
  .card {
    border-radius: 0.5rem;
    background: #fff;
    padding: 1rem;
  }

  .menuBlock {
    margin-left: 0.5rem;
    width: 100%;
    .menuItem {
      margin-right: 0.4rem;
      width: 9.5rem;
      height: 6rem;
      border-radius: 0.4rem;
      background: rgb(213, 231, 255);
      text-align: center;

      .menuTxt {
        font-size: 1.2rem;
        color: #666;
        margin-top: 0.8rem;
      }

      .menuNum {
        margin-top: 0.1rem;
        font-size: 2rem;
        font-weight: bold;
      }
    }
  }

  .topBlock {
    padding: 1rem 0 1rem 1rem;

    .topRight {
      position: absolute;
      right: 2rem;
      margin-top: 0.6rem;
      font-size: 0.9rem;
      color: rgb(120, 132, 150);
      padding-left: 1rem;
      border-left: 2px solid rgb(114, 175, 255);
    }

    .topTitle {
      font-size: 1.6rem;
      font-weight: bold;
    }

    .toptab {
      border-radius: 0.3rem;
      width: 8rem;
      height: 2.3rem;
      justify-content: center;
      /*子元素水平居中*/
      align-items: center;
      /*子元素垂直居中*/
      display: -webkit-flex;
      cursor: pointer;
    }
  }

  .tab-item-no {
    color: rgb(91, 139, 201);
    border: 1px solid rgb(91, 139, 201);
    background: #fff;
  }

  .tab-item-on {
    background: rgba(91, 139, 201, 0.3);
    border: 1px solid rgb(91, 139, 201);
    color: rgb(91, 139, 201);
  }
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2036862.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《光与夜之恋》3D建模含量超标,纯炫技还是释放新信号?

继叠纸的《恋与深空》之后&#xff0c;腾讯的《光与夜之恋》也卷起3D技术了。 《光与夜之恋》即将在8月12日上线的限定活动“大漠归墟”最新PV及男主六星卡面释出&#xff0c;相对于褒贬不一、引起争论的卡面美术&#xff0c;PV中的3D建模倒是收获了玩家的集体好评。 “大漠归…

读零信任网络:在不可信网络中构建安全系统18零信任代理

1. 零信任代理 1.1. 零信任代理是应用级代理服务器&#xff0c;用来保护零信任网络&#xff0c;它是处理认证、授权以及加密的基础设施 1.2. 零信任代理分为反向代理和前向代理两种工作模式 1.2.1. 运行时可以同时采用这两种工作模式&#xff0c;也可以只采用其中的一种 1.2…

libcurl8.9.1 上传json

在postman中 PUT----》body----》raw----》json 结构体定义&#xff1a; #define MAX_ARRAY_SIZE 5*1024*1024struct SMART_DATA_CACHE {char* buf;long dwTotalLen;SMART_DATA_CACHE(){dwTotalLen 0;buf nullptr;while (!buf) {try {buf new char[MAX_ARRAY_SIZE];}c…

C++:有序关联容器set

什么是有序关联容器 (1)顺序容器&#xff0c;容器中的元素是按它们在容器中的位置来顺序保存和访问的(可以理解是数组) (2)顺序容器有array、vector、deque、list、forward_list、string等 (3)关联容器中的元素是按关键字来保存和访问的&#xff0c;关联的意思就是关键字&…

STM32-外部中断-AFIO-串口-串口通信-串口中断(空闲中断和接收中断)-printf移植-ADC数模转换-初始化和读取光敏电阻AO

常用的中断包括外部中断、串口中断、定时器中断&#xff1b; 1、外部中断&#xff1a; 引脚复用按钮导致的外部中断&#xff1a; 注意&#xff1a;初始化引脚&#xff0c;添加引脚和EXTI输入线的映射&#xff1b;使用外部引脚的中断时需要使用AFIO映射&#xff1b; 操作步骤&…

如何获取android的SHA1或SHA256

在使用地图类的功能时&#xff0c;例如百度地图或者高德地图&#xff0c;会需要在开发者平台里填写SHA1或SHA256的指纹密钥&#xff0c;很多开发者小伙伴还不知道如何获取。当然关于如何获取android的SHA1或SHA256&#xff0c;网络上进行搜索已经有很多图文教程了&#xff0c;本…

mfc140u.dll丢失的科学修复手段,简单又方便的mfc140u.dll修复

遇到 "缺失 mfc140u.dll 文件" 的提示时可能会让你疑惑&#xff0c;但不用担心。这个文件是 Microsoft Visual C 2015 的重要组成部分&#xff0c;对运行特定程序非常关键。幸运的是&#xff0c;解决这一问题并不难。本文将简单指导你如何恢复或修复丢失的 mfc140u.d…

多台PC网络ADB连接同一台RK3399 Android7.1.2设备

在RK3399 Android7.1.2上面&#xff0c;进行网络ADB调试时&#xff0c;如果多台电脑连接同一台Android设备&#xff0c;第一台连接上的能正常操作&#xff0c;之后连接的看到设备状态为OFFLINE&#xff0c;分析了下ADBD相关代码&#xff0c;发现在ACCEPT Client的时候没有区分别…

设计师必备:2024最新PDF转CAD软件盘点

随着科技的飞速发展&#xff0c;设计师们不再受限于传统的设计流程&#xff0c;可以利用一些新欣的工具来提升工作效率、优化工作流程的新工具。其中&#xff0c;PDF转CAD工具成为了设计行业的一大热门话题。面对海量的数据和复杂的设计需求&#xff0c;一款高效、精准的PDF转C…

11、MySQL-SQL优化

目录 1、插入数据 1.1、批量插入 1.2、手动提交事务 1.3、主键顺序插入 1.4、大批量插入数据 2、主键优化 2.1 页分裂 2.2 主键顺序插入 2.3 主键乱序插入 2.4 页合并 2.5 主键的设计原则 3、order by优化 4、group by优化 5、limit优化 6、count优化 6.1 coun…

【Bifrost】ubuntu24.04 远程构建及clion设置编码风格google

Bifrost 构建通过clion 远程到ubuntu24.04 构建感觉是不认识这种写法,这种至少是c++11 fix : 修改absl 的构建cmakelist,明确c++17 好像还是不行error: ‘uint8_t’ was not declared in this scope加入:#include <stdint.h>可以解决一部分。那么,这种呢?/home/zha…

浅谈 DNS 篡改劫持

故事背景&#xff1a;产品反馈线上站点操作后跳转至空白页面&#xff0c;浏览器 URL 地址异常&#xff0c;ping 命令测试后定位可能是 DNS 解析异常&#xff0c;联系七牛云技术人员排查&#xff0c;反馈是由于带宽突变&#xff0c;触发节点防攻击策略所致&#xff0c;后续先调整…

keepalived安装-集群部署

1.服务器信息 服务器版本服务器IP介质版本安装用户CentOS Linux release 7.9.2009 (Core)192.168.10.244keepalived-2.2.8.tar.gz nginx-1.26.1 rootCentOS Linux release 7.9.2009 (Core)192.168.10.245keepalived-2.2.8.tar.gz nginx-1.26.1 root2.服务器基础配置 参考:Lin…

二、AI工作流(低代码)-输入-文本组件详解

对工作流感兴趣的小伙伴可以去试一试。&#x1f525;偷偷的告诉你&#xff0c;它的GPTo4.0 mini 不要&#x1f4b0;。传送门&#xff1a;https://www.nyai.chat/chat?invitenyai_1141439 一、能用AI工作流介绍 能用AI-工作流是一个“低代码”工具、它也是个人或者中小企业的…

Spring源码调试环境搭建(IDEA)

文章目录 引言开发环境搭建步骤步骤一&#xff1a;下载 Spring Boot 源码步骤二&#xff1a;导入项目到 IntelliJ IDEA步骤三&#xff1a;处理build报错报错一报错二 测试步骤新建module修改build.gradle新建测试类启动测试 引言 无论是面试&#xff0c;还是工作&#xff0c;S…

政安晨【零基础玩转各类开源AI项目】基于本地Ubuntu系统部署及应用歌唱语音转换框架NeuCoSVC:歌曲音色转换工具

目录 论文简介 部署 模型下载 编译REAPER 最后 政安晨的个人主页&#xff1a;政安晨 欢迎 &#x1f44d;点赞✍评论⭐收藏 希望政安晨的博客能够对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff01; 本文目标&#xff1a;《Neural Concate…

模拟三层--控制层、业务层和数据访问层

三层的概念:https://developer.aliyun.com/article/1390024 一、新建一个项目 我新建好的项目名为spring__ioc_02,然后在 src-main-java 下建立三层&#xff08;数据访问层、业务层和控制层&#xff09;的包 dao、service 和controller、并在包下建立相应的接口和实现类 Proje…

网络命令之查看网口最大网速的一些方法?(/sys/class/net/ethx/speed、ethtool ethx)

文章目录 背景方法1: sysfs的net方法2&#xff1a;ethtool方法3&#xff1a;通过网卡型号获取方法4&#xff1a;通过网卡lspci输出信息直接获取方法5&#xff1a;高性能网卡可以通过物理连线光口信息获取后记 背景 经常需要查看不同网卡的网速&#xff0c;甚至相同大版本型号网…

一个简单的pytorch项目框架

框架的基本功能&#xff1a; 1. 模型的定义、训练与测试 2. 数据生成与数据迭代器 3. 训练日志记录 4. 训练过程实时监控 有了这个框架&#xff0c;后续所有复杂的AI项目都可以在此基础上拓展开发。 项目基本结构&#xff1a; 四个文件&#xff1a; sequence_mean_generate…

C++初阶_2:引用

本节咱们来说说引用&#xff1a; C添加了“引用”&#xff0c;与指针成了两兄弟——这两兄弟对我们今后写C代码可谓各有特点&#xff0c;缺一不可。 何谓引用&#xff1f; 引用&#xff1a;就是取别名 不知诸位可有别名&#xff1f;这里不妨举一本耳熟能详的小说《水浒传》&…