【前端Vue】如何实现echarts图表根据父元素宽度自适应大小

当前我遇到的场景是页面侧边导航栏会产生展开和收缩的变化,其变化会挤压拉伸页面区域,如果echarts图表布局在这些区域,会影响到显示效果;并且当页面缩放时,图表也应当进行自适应变化。

这是导航菜单展开的效果

这是导航菜单收缩的效果

这是浏览器侧边栏打开的效果

这是浏览器缩放后的效果

实现代码如下:

我这里涉及到的是宽度的变化,因此需要在图表组件处将width设置为100%,如果高度也要自适应,跟宽度一样的原理

html 复制代码
<div ref="chart" style="width: 100%;height: 200px; "></div>

还需要将图表在echarts的配置代码中调整好合适的位置

javascript 复制代码
grid: {

          top: "12%",

          left: "2%",

          right: "2%",

          bottom: "3%",

          containLabel: true,

        },

随后在mounted()函数中添加使用ResizeObserver API(用于监听DOM节点变化的API,实现自适应的关键点)

javascript 复制代码
mounted() {

    this.$nextTick(() => {

      this.initChart();

      const resizeObserver = new ResizeObserver(entries => {

        for (const entry of entries) {

          const chartInstance = echarts.getInstanceByDom(entry.target);

          if (chartInstance) {

            chartInstance.resize();

          }

        }

      });



      resizeObserver.observe(this.$refs.chart);

    });

  },
相关推荐
Lee川5 小时前
Milvus 实战:当 RAG 遇上向量数据库,从"玩具 Demo"到"生产可用的"那一步
前端·数据库·人工智能
anOnion5 小时前
构建无障碍组件之Toolbar Pattern
前端·html·交互设计
惊鸿一博6 小时前
图标加载方式_zeroIcon_是否加前缀mdi
开发语言·前端·javascript
2501_940041746 小时前
前端工程化进阶:5个高交互与可视化项目提示词
前端
你很易烊千玺6 小时前
JS 异步 从零讲(大白话 + 真实场景 + 可运行案例)
前端·javascript·vue.js
why技术8 小时前
AI Coding开始进入第四个时代,我还没上车呢!
前端·人工智能·后端
大家的林语冰9 小时前
CSS 已死?DOM 性能黑洞!Pretext 排版革命让你在文本间跳舞,没有 DOM 也能纵享丝滑~
前端·javascript·css
vipbic9 小时前
我也该升级了,陪伴了我7年的博客
前端
Lee川9 小时前
RAG 实战:从一篇掘金文章出发,拆解检索增强生成的全链路
前端·人工智能·后端
Lee川9 小时前
MCP 高德地图实战:当 AI 学会使用工具,一个协议如何重塑大模型的行动边界
前端·人工智能·后端