【前端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);

    });

  },
相关推荐
张元清4 分钟前
head.tsx 就是一个 React 组件:用 loader 数据动态生成 SEO meta
前端·javascript·面试
前端那点事8 分钟前
Vue keep-alive 原理全解析(Vue2+Vue3适配)
vue.js
lemon_yyds9 分钟前
Element UI 实践踩坑- date-picker 组件 定制化type="daterange"
前端·css
Alice-YUE12 分钟前
ai对话平台中的functioncalling+mcp
前端·笔记·学习·语言模型
MXN_小南学前端31 分钟前
Vue 视频上传实战:视频预览、MediaRecorder 压缩与自定义上传
前端·vue.js
Hilaku44 分钟前
AI 生成的代码都是一坨屎?聊聊怎么给 Agent 制定工程约束
前端·javascript·ai编程
吴声子夜歌1 小时前
Vue3——使用Vue Router实现路由
前端·javascript·vue.js·vue-router
CDwenhuohuo1 小时前
小程序全局使用api
javascript·vue.js·小程序
whinc1 小时前
Node.js技术周刊 2026年第16周
前端·javascript
DyLatte1 小时前
我做了个AI项目后才发现:会做事的人,正在输给会讲故事的人
前端·后端·程序员