背景:项目有用到 vue-echarts, 百度推出的 vue 版本的 Echarts,图表自带响应式属性 auto-resize, 来实现窗口尺寸变化时,图表的尺寸自适应,可是发现它是靠监听 window 的 onresize 来实现的,而有时候当chart 容器 尺寸变化时,window 窗口大小是不变的,好比我此次遇到的,侧边菜单栏的显示隐藏切换,致使内容区域总体部分宽度会变化,可是window 没有变化,因此auto-resize 不能监听这种状况来实现 resize。javascript
解决思路:html
具体作法有如下几种:vue
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> </head> <body> <div id="demo" style="background: blue; height: 200px; width: 100%"> demo 内容 </div> <script> var observer = new MutationObserver(function (mutations, observer) { mutations.forEach(function (mutation) { console.log(mutation); }); }); var config = { attributes: true, attributeOldValue: true, attributeFilter: [ 'style' ] }; var el = document.getElementById('demo'); observer.observe(el, config); </script> </body> </html>
斟酌了上面几种方案后,结合具体案例,我以为仍是用 vuex 写全局数据更好更方便一些,具体步骤以下java
// 注意的坑,1.要设置 width 2. width 变化有延迟,须要加个 timeout,否则看不到效果 this.$refs.chart.resize({width: this.$refs.chart.offsetWidth})